알고리즘/알고리즘 풀이
[프로그래머스_1] 하샤드 수 JAVA
데부한
2022. 7. 1. 23:05
반응형
문제 설명
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.
제한 사항
- x는 1 이상, 10000 이하인 정수입니다.
입출력 예
반응형
CODE
class Solution {
public boolean solution(int x) {
String str = String.valueOf(x);
String[] numberArr = str.split("");
int sum = 0;
for(String num : numberArr) {
sum += Integer.parseInt(num);
}
return (x % sum == 0? true : false);
}
}
뭔가 멋들어진 '하샤드 수'라해서 어려운 공식인가 싶었는데 잘 읽어보면 그리 어려운 문제는 아니었다.
1. x의 각 자릿수 구하기
2. x의 각 자릿수를 더한 수 구하기
3. x를 x의 각 자릿수를 더한 수로 나눠 나눠지면 true, 나누어 떨어지지 않으면 false
이 순서대로 코드를 잘 작성하면 쉽게 풀 수 있다. 일단 x의 각 자릿수를 구하는 방법은 아래와 같다.
String str = String.valueOf(x);
String[] numberArr = str.split("");
먼저 x를 String 타입으로 만들었다. 그리고 문자열을 split() 함수를 사용해 각 자릿수를 numberArr 배열에 담았다. 즉 x가 10이라면 [1, 0]으로 담았다.
그리고 for문을 돌면서 각 자릿수를 더한 값을 구했다.
int sum = 0;
for(String num : numberArr) {
sum += Integer.parseInt(num);
}
주의할 점은 numberArr 배열에 있는 요소들은 String 타입이기 때문에 숫자 연산을 하려면 데이터 타입을 정수형으로 바꿔줘야한다. 그래서 Integer.parseInt()로 자릿수를 int 타입으로 변경하고 sum에 누적 저장했다.
마지막으로 return문에서 삼항연산자를 이용해 하샤드 수인지 판별했다.
return (x % sum == 0? true : false);
실행 결과
반응형