공부/프로그래머스

[프로그래머스 Lv. 1] 하샤드 수 - JAVA

해니0 2024. 8. 10. 08:00

문제

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

class Solution {
    public boolean solution(int x) {
        boolean answer = true;
        return answer;
    }
}

 

제한사항

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

 

입출력 예

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

 


문제 풀이

분석

하샤드 수(Harshad number) 또는 나브라 수(Nabraj number)는 주어진 수의 자릿수의 합으로 나누어 떨어지는 자연수

자릿수를 더한 후 나눴을때 0으로 나누어 떨어지는지 판별

 

Java에서 길이를 구하는 대표적인 메소드

종류 메소드
배열 .length
문자열 .length()
ArrayList .size()

 

문자열 숫자 변환

문자열을 숫자로 (String -> int)

java.lang.Integer 클래스의 parseInt()와 valueOf() 메소드

parseInt는  primitive type인 int를 리턴하고 valueOf는 Integer Object를 리턴함

Integer.parseInt(str1); 

Integer.valueOf(str1);

 

숫자를 문자열로 (int -> String)

Integer.toString()과 String.valueOf() 메소드

Integer.toString(intValue1);

String.valueOf(intValue1);

 

내 소스 코드

class Solution {
    public boolean solution(int x) {
        int sumOfDigits = 0;
        int originalNumber = x;
        
        // 숫자의 각 자릿수를 더함
        while (x > 0) {
            sumOfDigits += x % 10; // 마지막 자릿수 추출
            x /= 10; // 마지막 자릿수를 제거
        }
        
        // 원래 숫자가 자릿수의 합으로 나누어 떨어지면 true, 그렇지 않으면 false
        return originalNumber % sumOfDigits == 0;
    }
}

 

다른 풀이 1

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

 

추가로 고민 할 부분

한번씩 봤던 함수들이 반복된다

자주 사용하는건 별도로 메모하고 공부하기


Lv.1  / Java / 연습문제

출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges