Algorithm/프로그래머스
[프로그래머스]연습문제 : 약수의 합 (level 1)
HBGB
2019. 11. 7. 00:16
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
|
* 제곱수 케이스에 주의