Lv1_약수의 개수와 덧셈

Eugenius1st·2022년 8월 28일
0

Programmers_JavaScript

목록 보기
18/30
post-thumbnail

Lv1_약수의 개수와 덧셈

문제

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

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

풀이

  • for문 돌려서 약수의 개수를 카운팅 한다
  • 카운팅한 약수가 짝수라면 answer 에 그 수를 더한다
  • 카운팅한 약수가 홀수라면 answer 에 그 수를 뺀다

코드

function solution(left, right) {
  var answer = 0;
  let numCnt = 0;
  for (let i = left; i <= right; i++) {
    for (let x = 1; x <= i; x++) {
      if (i % x === 0) numCnt++;
    }
    numCnt % 2 === 0 ? (answer += i) : (answer -= i);
    numCnt = 0;
  }
  return answer;
}

배운것

  • 제곱근이 정수면 약수의 갯수가 홀수이다.. 당연하지. 약수는 x*y 가 되는 수이므로
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;
}
profile
최강 프론트엔드 개발자가 되고싶은 안유진 입니다

0개의 댓글