(프로그래머스)하샤드 수

김주란·2021년 11월 11일
0

Algorithm

목록 보기
10/13

문제 설명

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

제한 조건

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

입출력 예

arrreturn
10true
12true
11false
13false

풀이

import java.util.*;

class Solution {
    public boolean solution(int x) {
        int sum = 0;
       //String[] temp = String.valuOf(x).split("");
        String[] temp = (x + "").split("");
        System.out.println(Arrays.toString(temp));
        
        int[] array = new int[temp.length];
        for(int i = 0; i<temp.length; i++) {
            array[i] = Integer.parseInt(temp[i]); // str -> int로 형변환 필요. 
        }
        for(int num:array) {
            sum += num;
        }
        return x % sum == 0;
    }
}

x를 나눠서 string 배열로 만들고 다시 int배열로 바꿨다.
근데 sum만 얻으면 되는 문제니깐 굳이 int배열로 바꿀 필요가 없었다.
String 배열 자체에서 반복문을 통해 sum을 구해주면 더 간단하다.

import java.util.*;

class Solution {
    public boolean solution(int x) {
         int sum = 0;
        String[] temp = (x + "").split("");
        System.out.println(Arrays.toString(temp));

        for(String num :temp) {
            sum += Integer.parseInt(num);
        }
        return x % sum == 0;
    }
}

0개의 댓글