약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요.
● 1 ≤ n ≤ 100
10 이하 합성수는 4, 6, 8, 9, 10 로 5개입니다. 따라서 5를 return합니다.
15 이하 합성수는 4, 6, 8, 9, 10, 12, 14, 15 로 8개입니다. 따라서 8을 return합니다.
function solution(n) {
let arr = [];
for (let i = 1; i <= n; i++) {
for (let j = n; j > 0; j--) {
if (j <= i) {
if (i % j === 0) {
arr.push(i);
}
}
}
}
const reusult = {};
const results = [];
arr.forEach((a) => (reusult[a] = (reusult[a] || 0) + 1));
for (let i = 1; i <= n; i++) {
if (reusult[i] > 2) {
results.push(i);
}
}
return results.length
}
이제까지 풀은 문제 중에 역대급으로 어려웠다.
일단 합성수라는 개념자체가 이해가 되지 않았다.
그래서 이렇게 긴 코드가 나온 것 같았다.
약수도 아니고 소수도 아니고...
끝!