프로그래머스 level 1 : 하샤드 수
- 문제설명
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.
- 제한사항
x는 1 이상, 10000 이하인 정수입니다.
- 입출력 예
문제풀이
class Solution {
public boolean solution(int x) {
boolean answer = true;
String temp = x+"";
String [] temps = temp.split("");
int num = 0;
for(int i = 0; i<temps.length; i++){
num += Integer.parseInt(temps[i]);
}
if(x%num != 0){
answer = false;
}
return answer;
}
}
풀이설명
파라미터로 넘어온 값을 배열에 담기 위해 String으로 변환 후 split을 사용하여 배열에 담는다.
더한 수를 저장하기 위한 변수를 선언한다.
for문을 사용하여 선언한 변수에 배열의 값을 더해준다.
조건을 걸어 나머지가 0이 아닐 경우 answer의 값을 false로 변경한다.
'문제풀이 > programmers' 카테고리의 다른 글
[프로그래머스] 오랜 기간 보호한 동물(2) - MySQL (0) | 2021.10.15 |
---|---|
[프로그래머스] 수박수박수박수박수박수? - Java (0) | 2021.09.15 |
[프로그래머스] 가운데 글자 가져오기 - Java (0) | 2021.09.15 |
[프로그래머스] 문자열 내림차순으로 배치하기 - Java (0) | 2021.09.15 |
[프로그래머스] 정수 내림차순으로 배치하기 - Java (0) | 2021.09.15 |