✔문제 설명
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
✔입출력 예
left right result
13 | 17 | 43 |
24 | 27 | 52 |
✔나의 풀이
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;
}
제곱근이 정수면 약수의 개수가 홀수가 된다는것을 깨달았다.
'알고리즘 > 자바스크립트-프로그래머스' 카테고리의 다른 글
[프로그래머스 | Javascript] 코딩테스트 Lv1 - 부족한 금액 계산하기 (0) | 2023.01.02 |
---|---|
[프로그래머스 | Javascript] 코딩테스트 Lv1 - 문자열 다루기 기본 (0) | 2023.01.02 |
[프로그래머스 | Javascript] 코딩테스트 입문 - 숨어있는 숫자의 덧셈 (2) (0) | 2022.12.28 |
[프로그래머스 | Javascript] 코딩테스트 입문 - 외계어 사전 (0) | 2022.12.28 |
[프로그래머스 | Javascript] 코딩테스트 입문 - 잘라서 배열로 저장하기 (0) | 2022.12.27 |