프로그래머스 (JS)/Lv. 1

[Programmers / JS] 77884번 - 약수의 개수와 덧셈

hodo- 2023. 3. 16. 13:26

Problem

문제 보기

두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.


Solution

function solution(left, right) {
    let answer = 0;
    let count = 0;
    
    for(let i = left; i <= right; i++){
        for(let j = 1; j <= i; j++){
            if(i % j === 0) count++;
        } if(count % 2 === 0) {
            answer += i;
        } else answer -= i;
        count = 0;
    }
    return answer;
}

다른 풀이를 보니

function solution(left, right) {
    var answer = 0;
    for (let i = left; i <= right; i++) {
        if (Number.isInteger(Math.sqrt(i))) {
            answer -= i;
        } else {
            answer += i;
        }
    }
    return answer;
}

약수의 개수가 홀수라면 제곱근이 정수라는 공식을 알 수 있었