문제 설명
정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요.
제한 사항- n은 0 이상 3000이하인 정수입니다.
내 코드:
function solution(n) {
let sum = 0
for (let i=1; i<=Math.sqrt(n); i++) {
if (i === Math.sqrt(n)) sum += i //제곱근 약수는 1개만 더함
else if (n % i === 0) sum += i + n/i
}
return sum
}
Math.sqrt 까지만 반복문을 수행해서 반복 횟수를 줄였다. 그리고 제곱근이 정수인 수의 약수는 홀수이므로 1개만 더했고, 나머지는 2번씩 더해줬다.
'알고리즘' 카테고리의 다른 글
[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 |