[CODING TEST]::LV1 약수의 개수와 덧셈

kimsoyeon·2022년 4월 8일
0
post-custom-banner

[문제]

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

[제한]

  • 1 ≤ left ≤ right ≤ 1,000

[입출력 예]

leftrightreturn
131743
242752

[입출력 예 설명]

입출력 예 #1
-다음 표는 13부터 17까지의 수들의 약수를 모두 나타낸 것입니다.

약수약수의 개수
131, 132
141, 2, 7, 144
151, 3, 5, 154
161, 2, 4, 8, 165
171, 172

-따라서, 13 + 14 + 15 - 16 + 17 = 43을 return 해야 합니다.

입출력 예 #2
-다음 표는 24부터 27까지의 수들의 약수를 모두 나타낸 것입니다.

약수약수의 개수
241, 2, 3, 4, 6, 8, 12, 248
251, 5, 253
261, 2, 13, 264
271, 3, 9, 274

-따라서, 24 - 25 + 26 + 27 = 52를 return 해야 합니다.

[answers.js]

function solution(left, right) {
  let answer = 0;
  let num = 0;

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

[codesandbox]
https://codesandbox.io/s/coding-test-daily-29-zyl2q9

profile
i am korean dobby
post-custom-banner

0개의 댓글