합성수 찾기(Javascript)

·2022년 10월 18일
1
post-thumbnail

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

제한사항

1 ≤ n ≤ 100

입출력 예

nresult
105
158

입출력 예 설명

입출력 예 #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객체에 넣어 준 이유는 중복을 제거하기 위해서이다.

profile
전 이것도 몰라요

0개의 댓글