[Java] 약수의 합 (programmers)

Haeun Noh·2022년 8월 30일
0

programmers

목록 보기
3/64
post-thumbnail

0830


문제 설명

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


제한 사항

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

입출력 예

nreturn
1228
56

입출력 예 설명

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

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


소스 코드

class Solution {
    public int solution(int n) {
        int answer = 0;
        
        for ( int i = 1; i <= n; i++ ) {
            if ( n % i == 0 )
                answer+=i;
        }
        
        return answer;
    }
}

소스 풀이

	int answer = 0;

모든 n의 약수의 합을 저장할 변수 answer를 선언 및 초기화한다.


		for ( int i = 1; i <= n; i++ ) {
            if ( n % i == 0 )
                answer+=i;
        }
        return answer;

i의 값이 n의 값이 될 때까지 for문을 반복하며 i++을 수행한다.

만약 i의 값이 n의 값을 나눌 때 나머지가 0이라면 answer변수에 i를 더하여 모든 n의 약수의 합을 구한다.

n의 모든 약수의 합을 return한다.



profile
기록의 힘을 믿는 개발자, 노하은입니다!

0개의 댓글