[프로그래머스] Lv.1 약수의 합 JavaScript

Janet·2023년 2월 22일
0

Algorithm

목록 보기
22/314

문제 설명

정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요.

제한 사항

  • n은 0 이상 3000이하인 정수입니다.

입출력 예

nreturn
1228
56

입출력 예 설명

입출력 예 #112의 약수는 1, 2, 3, 4, 6, 12입니다. 이를 모두 더하면 28입니다.

입출력 예 #25의 약수는 1, 5입니다. 이를 모두 더하면 6입니다.


문제풀이

💡 문제풀이 과정

  • 약수란? 정수 n을 0이 아닌 정수 i로 나누었을 때 나누어떨어지는 경우, 즉 몫이 정수이고 나머지가 0인 경우 d를 i의 약수라고 한다. d가 n의 약수이면 i는 d의 배수이다.
    • 예시) 2는 4의 약수이고, 4는 2의 배수이다. 4의 약수는 1, 2, 4 총 3개이다.
  • 답안 #1: for 반복문을 사용하고, n을 i로 나누었을 때 나머지가 0인 경우에는 빈 어레이에 push()를 사용하여 담아주었다. 그리고 그 배열에 담긴 값들의 합은 reduce() 함수를 이용하여 내준다.
  • 답안 #2: 굳이 배열을 만들 필요없이 answer = answer + i를 해도 된다.

✅ 답안 #1

function solution(n) {
  let arr = [];
  for (let i = 1; i <= n; i++) {
    if (n % i === 0) arr.push(i);
  }
  return arr.reduce((a, b) => a + b);
}

✅ 답안 #2

function solution(n) {
  let answer = 0;
  for (let i = 1; i <= n; i++) {
    if (n % i === 0) answer += i
  }
  return answer;
}
profile
😸

0개의 댓글