문제 ) 프로그래머스 - 하샤드 수(lv.1)
📌 문제 설명
양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.
📌 제한 사항
- x는 1 이상, 10000 이하인 정수입니다.
📌 입출력 예
x | return |
10 | true |
12 | true |
11 | false |
13 | false |
✏️ map(int, str) / sum()
def solution(x):
a = sum(map(int, str(x)))
return x % a == 0
✏️ for() / sum()
def solution(x):
answer = 0
for i in str(x):
answer += int(i)
return x % answer == 0
# 한 줄로 변경
# return x % sum(int(i) for i in str(x)) == 0
'알고리즘 > Python 기초' 카테고리의 다른 글
파이썬 - 콜라츠 추측(lv.1) (0) | 2023.05.21 |
---|---|
파이썬 - 두 정수 사이의 합(lv.1) (0) | 2023.05.21 |
파이썬 - 정수 내림차순으로 배치하기(lv.1) (0) | 2023.05.21 |
파이썬 - 문자열을 정수로 바꾸기(lv.1) (0) | 2023.05.21 |
파이썬 - 정수 제곱근 판별(lv.1) (0) | 2023.05.21 |