📕 문제 설명
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
⭐ 제한사항
- 1 ≤ left ≤ right ≤ 1,000
💻 입출력 예
left | right | result |
13 | 17 | 43 |
24 | 27 | 52 |
📚 입출력 예 설명
입출력 예 #1
- 다음 표는 13부터 17까지의 수들의 약수를 모두 나타낸 것입니다.
입출력 예 #2
- 다음 표는 24부터 27까지의 수들의 약수를 모두 나타낸 것입니다.
- 따라서, 24 - 25 + 26 + 27 = 52를 return 해야 합니다.
😊 나의 답변
function solution(left, right) {
let answer = 0;
for(let i = left; i <= right; i++) {
let count = 0;
for(let j = 1; j <= i; j++) {
if(i % j === 0) count++;
}
count % 2 ? answer -= i : answer += i;
}
return answer;
}
⭐ 감탄한 답변
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;
}
약수는 대칭을 이루는데, 제곱근만이 자기자신과 대칭을 이루기 때문에 제곱근이 정수면 약수의 개수가 홀수다...
천잰가 🙄
728x90
반응형
'프로그래머스 > Lv. 1' 카테고리의 다른 글
[프로그래머스] Lv.1 부족한 금액 계산하기 / JS (0) | 2023.08.30 |
---|---|
[프로그래머스] Lv.1 문자열 내림차순으로 배치하기 / JS (0) | 2023.08.30 |
[프로그래머스] Lv.1 내적 / JS (0) | 2023.08.30 |
[프로그래머스] Lv.1 수박수박수박수박수박수? / JS (0) | 2023.08.30 |
[프로그래머스] Lv.1 가운데 글자 가져오기 / JS (0) | 2023.08.30 |