프로그래머스 Lv 1. 약수의 개수의 덧셈

context·2023년 3월 6일
0

프로그래머스

목록 보기
17/24

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

  • 제한사항
    1 ≤ left ≤ right ≤ 1,000

나의 풀이

function solution(left, right) {
    var answer = 0;
    var a = []
    for(i=left; i<=right; i++){
        for(j=1; j<=i; j++){
            if(i % j === 0) a.push(i);
        }
        a.length % 2 === 0 ? answer += i : answer -= i
        a = []
    }
    return answer;
}

이중 for문의 사용
left부터 right 까지의 숫자를 하나씩 바깥 for문을 통해서 계산하고, 해당 숫자로 1부터 해당 숫자까지의 수를 안쪽 for문을 통해서 계산해, 약수를 구해 a 배열에 넣어 한 숫자의 약수를 다 구하면, 홀짝을 구분해 더하거나 빼고, a 배열을 초기화시켰다. 이후에 다음 값으로 넘어간다.

다른 사람의 풀이

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;
}

제곱근이 정수면 약수의 개수가 홀수다

0개의 댓글