Algorithm/Programmers

Programmers / Level 1 / 하샤드 수

Gyuri 2022. 5. 29. 23:11

[문제설명]

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

[제한사항]

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

[입출력 예]

10 true
12 true
11 false
13 false

 

class Solution {
    public boolean solution(int x) {
        boolean answer = true;
        
        int num = 0; // x의 자릿수의 합
        int a = x;
        
        while(a >= 1) { 
            num += a%10;
            a /= 10;
        }
        
        if(x % num == 0) { 
            answer = true;
        }
        else {
            answer = false;
        }
        
        return answer;
    }
}

 

테스트 케이스에 나와있는 수들은 모두 두자리수였기 때문에

num = x/10 + x%10 이런식으로 코드를 구현했는데,

x의 범위가 1~10000 까지 가능하기 때문에 세자리수, 네자리수의 경우 또한 생각해줘야 했다.

int형 변수를 하나 더 생성해 while문을 사용해 그 문제를 해결해줬다.

 

코드가 길거나 복잡하진 않지만, 시간이 꽤 오래 걸렸다.