프로그래머스 - 함성수 찾기

이한결·2022년 12월 10일
0

프로그래머스

목록 보기
60/107
post-thumbnail

문제 설명

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

제한사항

● 1 ≤ n ≤ 100

입출력 예

입출력 예 설명

입출력 예 #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 = [];
        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
}

이제까지 풀은 문제 중에 역대급으로 어려웠다.
일단 합성수라는 개념자체가 이해가 되지 않았다.
그래서 이렇게 긴 코드가 나온 것 같았다.
약수도 아니고 소수도 아니고...

끝!

profile
평범한 삶을 위하여

0개의 댓글