[Programmers] 코딩테스트 입문 12947. 하샤드 수

이지현·2023년 4월 12일
0

Algorithm

목록 보기
74/81
post-thumbnail

✔️ Problem URL

하샤드 수


✔️ Problem

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


✔️ Code

import java.util.stream.Stream;

class Solution {
    public boolean solution(int x) {
        int[] arr = Stream.of(String.valueOf(x).split("")).mapToInt(Integer::parseInt).toArray();
        boolean answer = false;
        int sum = 0;
        
        for(int i : arr) {
            sum += i;
        }
        if(x % sum == 0) answer = true;
        return answer;
    }
}

✔️ Refactoring

class Solution {
    public boolean solution(int x) {
        String[] strArr = String.valueOf(x).split("");
        boolean answer = false;
        int sum = 0;
        
        for(String s : strArr) {
            sum += Integer.parseInt(s);
        }
        if(x % sum == 0) answer = true;
        return answer;
    }
}
profile
2023.09 ~ 티스토리 이전 / 2024.04 ~ 깃허브 블로그 이전

0개의 댓글