합성수 찾기

yejichoi·2023년 2월 14일
0

알고리즘 스터디

목록 보기
4/153

합성수 찾기

약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요.

nresult
105
158

입출력 예 설명

⚡️ 입출력 예 #1

10 이하 합성수는 4, 6, 8, 9, 10 로 5개입니다. 따라서 5를 return합니다.

⚡️ 입출력 예 #2

15 이하 합성수는 4, 6, 8, 9, 10, 12, 14, 15 로 8개입니다. 따라서 8을 return합니다.


풀이

function solution(n) {
   var answer = 0
   
   for(let i = 1; i <= n; i++) {
       let count = 0 // for문 안에 선언을 해야만 count가 i값에 따라 리셋됨
       for(j = 1; j <= i; j++) { // i와 약수 비교
           if(i % j === 0) // 나눠 떨어진다면 (약수라면)
             count ++
         console.log(i,j, count)
       }
       
       if(count > 2) { // 약수가 3개 이상
           answer += 1
       }
   }
   
   return answer
}

0개의 댓글