럿고의 개발 노트

[프로그래머스] 하샤드 수 본문

Java Note/Algorithmus

[프로그래머스] 하샤드 수

KimSeYun 2020. 2. 1. 14:52

[프로그래머스] 코딩테스트 연습

하샤드 수

간략한 문제 풀이

문제 및 풀이

문제 설명

양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.

제한 조건

x는 1 이상, 10000 이하인 정수입니다.

입출력 예

arr return
10 true
12 true
11 false
13 false

입출력 예 설명

입출력 예 #1

10의 모든 자릿수의 합은 1입니다. 10은 1로 나누어 떨어지므로 10은 하샤드 수입니다.

입출력 예 #2

12의 모든 자릿수의 합은 3입니다. 12는 3으로 나누어 떨어지므로 12는 하샤드 수입니다.

입출력 예 #3

11의 모든 자릿수의 합은 2입니다. 11은 2로 나누어 떨어지지 않으므로 11는 하샤드 수가 아닙니다.

입출력 예 #4

13의 모든 자릿수의 합은 4입니다. 13은 4로 나누어 떨어지지 않으므로 13은 하샤드 수가 아닙니다.

/**
 * @ClassName : HarshadNumber
 * @ProblemName : 하샤드 수
 * @URL : https://programmers.co.kr/learn/courses/30/lessons/12947
 */
public class HarshadNumber {
    public boolean solution(int x){
        char[] harshads = Integer.toString(x).toCharArray();
        int harshadSum = 0;

        for (char harshad : harshads){
            harshadSum += Integer.parseInt(Character.toString(harshad));
        }

        return (x % harshadSum == 0);
    }

    // Test Case
    public static void main(String[] args) {
        HarshadNumber harshadNumber = new HarshadNumber();
        int arr1 = 10;
        int arr2 = 12;
        int arr3 = 11;
        int arr4 = 13;

        System.out.println(harshadNumber.solution(arr1));
        System.out.println(harshadNumber.solution(arr2));
        System.out.println(harshadNumber.solution(arr3));
        System.out.println(harshadNumber.solution(arr4));
    }
}
Comments