약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요.
1 ≤ n ≤ 100
n | result |
---|---|
10 | 5 |
15 | 8 |
입출력 예 #1
10 이하 합성수는 4, 6, 8, 9, 10 로 5개입니다. 따라서 5를 return합니다.
입출력 예 #1
15 이하 합성수는 4, 6, 8, 9, 10, 12, 14, 15 로 8개입니다. 따라서 8을 return합니다.
function solution(n) {
let arr = new Set();
for(let i = 1; i <= n; i++){
for(let j = 2; j < i; j++){
if(i % j === 0)
arr.add(i);
}
}
return arr.size;
}
1에서 n까지의 자연수를 1과 n을 제외한 수로 나누어 주었다. 만약 그 수가 나누어 떨어진다면 set 객체에 더해 주었다. set객체에 넣어 준 이유는 중복을 제거하기 위해서이다.