본문 바로가기
Coding Test

231011 하샤드 수 - Level 1

by mmm- 2023. 10. 11.

문제 설명

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

제한사항

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

 

입출력 예

 

입출력 설명

입출력 예 #1

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

입출력 예 #3

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

입출력 예 #4

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

입출력 예 #2

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

코드

1.

class Solution {
    public boolean solution(int x) {
        boolean answer = true;
        int sum = 0, temp = x;

        while(temp != 0) {
            sum += temp%10;
            temp /= 10;
        }
        
        if(x%sum != 0) 
            answer = false;
        
        return answer;
    }
}

 

2.

import java.util.*;

class Solution {
    public boolean solution(int x) {
        boolean answer = true;
        char[] ch = String.valueOf(x).toCharArray();
        int sum = 0;
        
        for(int i=0; i<ch.length; i++) {
            sum += Character.getNumericValue(ch[i]);
        }
        
        if(x%sum != 0)
            answer = false;
        
        return answer;
    }
}

 

풀이

1. sum변수에는 0을, temp라는 변수에는 x를 할당해준다. 각 자릿수의 합을 더하기 위해 while문을 이용해 temp가 0이 될 때까지 temp%10를 sum에 더하고, temp를 10으로 나눠주는 과정을 반복한다. 그리고 반복문이 끝나면 x를 sum으로 나눈 값이 0이 아니면 false를, 맞다면 true를 리턴한다.

 

2. char형 배열을 생성하여 x의 각 자릿수를 넣어준다. for 문을 이용해 각 자릿수를 int형으로 변환한 값을 더해 sum에 할당해준다. 반복문이 끝나면 x를 sum으로 나눈 나머지가 0이 아니면 false, 0이면 true를 리턴한다.


다른 코드와 풀이

아래의 코드는 다른 사람들이 작성한 것들로, 내 코드와 비교, 참고하기 위해 가져왔다.

class Solution {
    public boolean solution(int x) {
        int sum = String.valueOf(x).chars().map(ch -> ch - '0').sum();
        return x % sum == 0;
    }
}

x를 문자열로 변환 후 chars()를 이용해 String 스트림 문자열로 만들어준다. 그리고 각 문자를 정수형으로 변환한 후 더해준다.