[Problem Solving] 약수의 개수와 덧셈

Sean·2023년 1월 3일
0

Problem Solving

목록 보기
16/130

문제

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

통과한 코드

function getYaksuNum(num) {
    let ret = 0;
    for(let i=0; i<=Math.sqrt(num); i++) {
        if(num % i == 0) {
            if(i == Math.sqrt(num)) ret++;
            else ret += 2;
        }
    }
    
    return ret;
}

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

더 좋은 풀이

💡어떤 수의 제곱근이 정수이면, 그 수의 약수의 개수는 홀수임을 활용한 코드

function solution(left, right) {
    var answer = 0;
    
    for(let i=left; i<=right; i++) {
        Number.isInteger(Math.sqrt(i)) ? answer -= i : answer += i;
    }
    
    return answer;
}
profile
여러 프로젝트보다 하나라도 제대로, 깔끔하게.

0개의 댓글