알고리즘-2021/04/18

sanghun Lee·2021년 4월 18일
0

알고리즘

목록 보기
25/52
post-thumbnail

문제 설명

정수 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입니다.

풀이

function solution(n) {
    var answer = 0;
    let newArr = [];
    for(let i = 1; i < n+1; i++){
        if(n%i === 0){
          newArr.push(i);
        }
    }
    console.log(newArr);
    newArr.forEach((el)=>{
     answer += el;
})
    return answer;
}

자기보다 작은 수 중 나눠지는 숫자가 있으면 약수이니 해당하는 것들을 배열에 넣고 배열의 합을 구했다.

끝!

참고

profile
알고리즘 풀이를 담은 블로그입니다.

0개의 댓글