문제 설명
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ left ≤ right ≤ 1,000
내 코드:
function solution(left, right) {
let sum = 0
for (let i =left; i<right+1; i++) {
if (Number.isInteger(Math.sqrt(i))) sum -= i
else sum +=i
}
return sum
}
홀수인 경우는 제곱근이 정수인 경우와 같으므로 if 조건을 추가해서 - 해줬다. 그렇지 않은 수는 + 해주고 i 는 left 에서 시작하며 right +1 까지 반복문을 수행한다.
'알고리즘' 카테고리의 다른 글
[JS] 자바스크립트 Math 함수 정리 (0) | 2024.02.28 |
---|---|
[프로그래머스] 약수의 합 (JavaScript) (0) | 2023.06.21 |
[프로그래머스] 시저 암호 (JavaScript) (0) | 2023.06.21 |
[프로그래머스] 숫자 문자열과 영단어 (JavaScript) (0) | 2023.06.21 |
[프로그래머스] 소수만들기 (JavaScript) (0) | 2023.06.21 |