본문 바로가기

코딩테스트/프로그래머스

[프로그래머스][JAVA] 하샤드 수 (LV.1)

반응형

 문제 설명

양의 정수 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은 하샤드 수가 아닙니다.

 


나의 풀이
class Solution {
    public boolean solution(int x) {
        boolean answer = true;
        
        String s = Integer.toString(x);
        String[] str = new String[s.length()];
        for(int i=0; i<s.length(); i++) {
            str[i] = s.substring(i, i+1);    
        }
        
        int n = 0;
        
        for(int i=0; i<str.length; i++) {
            n += Integer.parseInt(str[i]);
        }
        
        
        if(x % n == 0) {
            answer = true;
        } else {
            answer = false;
        }
        
        return answer;
    }
}

 

다른 사람의 풀이
class Solution {
    public boolean solution(int x) {
        int sum = String.valueOf(x).chars().map(ch -> ch - '0').sum();
        return x % sum == 0;
    }
}
728x90
반응형