-
[Java/프로그래머스] 하샤드 수코딩테스트 2024. 2. 6. 12:05
https://school.programmers.co.kr/learn/courses/30/lessons/12947
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1. 문제설명
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.제한 조건
- x는 1 이상, 10000 이하인 정수입니다.
입출력 예
xreturn
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은 하샤드 수가 아닙니다.2. 문제풀이
잘못된 풀이
class Solution { public boolean solution(int x) { boolean answer = true; int temp = 0; do { temp += x % 10; } while (x < 10); if(temp % x == 0) { answer = true; } else if(temp % x !=0) { answer = false; } return answer; } }
정답
class Solution { public boolean solution(int x) { boolean answer = true; int origX = x; int temp = 0; while(x != 0) { temp += x % 10; x /= 10; } if (origX % temp == 0) { return answer; } else { return false; } } }
while문안에 조건문을 x==0으로 시도했다가 계속 실패했다. 조건문은 x != 0으로 바꿔줬더니 성공하였다.
'코딩테스트' 카테고리의 다른 글
[Java/프로그래머스] 시저 암호 (0) 2024.02.09 [Java/프로그래머스] 나누어 떨어지는 숫자 배열 (0) 2024.02.09 [Java/프로그래머스] 문자열 내 p와 y의 개수 (0) 2024.02.06 [Java/프로그래머스] 자릿수 더하기 (1) 2024.02.06 [Java/프로그래머스] Lv.1 가장 가까운 같은 글자 (0) 2024.02.03