본문 바로가기
Algorithm/프로그래머스

[프로그래머스]연습문제 : 약수의 합 (level 1)

by HBGB 2019. 11. 7.

https://programmers.co.kr/learn/courses/30/lessons/12928

 

코딩테스트 연습 - 약수의 합 | 프로그래머스

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

programmers.co.kr

 

방법 1: 편한 답안 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Solution {
  public int solution(int n) {
 
    int iSum = 0;
 
    for (int i = 1; i <= n; i++) {
      if (n % i == 0) {
        iSum += i;
      }
    }
 
    return iSum;
  }
}
Colored by Color Scripter

 

방법 2: 조금 더 생각하는 답안

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class Solution {
  public int solution(int n) {
 
    int iSum = 0;
 
    for (int i = 1; i * i <= n; i++) {
      if (n % i == 0) {
 
        iSum += i;
        
        // 제곱수가 아니라면 대칭되는 약수도 더하기
        if (i != (n / i)) {
          iSum += (n / i);
        }
      }
    }
    return iSum;
  }
}
Colored by Color Scripter

 

 

* 제곱수 케이스에 주의

 

댓글