티스토리 뷰
문제
정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요.
제한 조건
n
은 0 이상 3000 이하인 정수입니다.
입출력 예
n | return |
---|---|
12 | 28 |
5 | 6 |
입출력 예 설명
입출력 예 #1
12의 약수는 1, 2, 3, 4, 6, 12입니다. 이를 모두 더하면 28입니다.입출력 예 #2
5의 약수는 1, 5입니다. 이를 모두 더하면 6입니다.
접근
약수는 해당 숫자를 나누어 떨어지게 한다.
반복문으로 약수를 구하고 reduce()
로 총합을 구하자.
구현
const solution = n => {
let answer = 0;
// 약수를 담을 배열
const measures = [];
// 나누어 떨어지는 숫자가 약수
for (let i = 1; i <= n; i++) {
if (n % i === 0) {
measures.push(i);
}
}
// 총합 구하기. n이 0일 때를 고려하여 초기값을 설정한다.
answer = measures.reduce((a, v) => a + v, 0);
return answer;
};
다루어야 할 숫자가 0을 포함한다면 항상 조심하자.
반응형
'프로그래머스 문제풀이 > Level 1' 카테고리의 다른 글
[프로그래머스] 수박수박수박수박수박수? (0) | 2020.04.11 |
---|---|
[프로그래머스] 최대공약수와 최소공배수 (0) | 2020.04.09 |
[프로그래머스] 짝수와 홀수 (0) | 2020.04.08 |
[프로그래머스] 핸드폰 번호 가리기 (0) | 2020.04.08 |
[프로그래머스] 자릿수 더하기 (0) | 2020.04.08 |
댓글