[파이썬][프로그래머스] 하샤드 수
1. 문제
[level 1] 하샤드 수 - 12947
성능 요약
메모리: 10.4 MB, 시간: 0.02 ms
구분
코딩테스트 연습 > 연습문제
채점결과
정확성: 100.0
합계: 100.0 / 100.0
문제 설명
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.
제한 조건
x
는 1 이상, 10000 이하인 정수입니다.
입출력 예
arr | 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은 하샤드 수가 아닙니다.
출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges
2. 해결방법 시간복잡도
- 단순 코딩 O(N)
3. 문제 해결 및 코드
-
주석을 참고하면서 이해를 돕습니다.
4. 알고리즘 및 해설
- 숫자로 이루어진 값을 문자로 받은 이후에 해당 문자내 값들을 반복문을 통해 나눈다.
- 이후 해당 문자로 이루어진 리스트를 다시 숫자로 되받아 값을 더해준다.
- 처음 받은 값이 위에 과정을 거쳐 받은 값으로 나누어서 떨어지면 True를 아니라면 False를 출력한다.
5. 짚고 넘어가기
하샤드 수
x를 x의 자리수의 합으로 나누었을 때 나누어지는 수