본문 바로가기

programmers-코딩테스트 연습/Level 1. 자바

2021-06-09 / 약수의 합

문제 설명

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

 

 


초기 코드

class Solution {
    public int solution(int n) {
        int answer = 0;
        return answer;
    }
}

정답 코드

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;
    }
}

 

코드 설명

약수는 어떤 수를 나눴을 때 나머지가 0인 수이다. 즉 최소는 1부터 최대는 자기 자신까지다. 반복문을 1부터 n까지 돌리고 만약 n을 나눈 수의 나머지가 없을 경우에 그 수는 약수가 된다.

 

 

 

 

코딩테스트 연습 - 약수의 합

정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요. 제한 사항 n은 0 이상 3000이하인 정수입니다. 입출력 예 n return 12 28 5 6 입출력 예 설명 입출력 예 #1 12의 약수

programmers.co.kr