728x90
문제 설명
양의 정수 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. str->list를 이용해서 arr를 자릿수로 분리해준다.
2. list->map->int를 이용해서 리스트를 숫자형으로 변환시켜준다.
3. sum으로 리스트의 총합을 구해준다.
4. arr가 num로 나누어 떨어지면 True, 아니면 False로 반환시켜준다.
나의 코드
def solution(arr):
num = list(map(int, list(str(arr))))
num = sum(num)
if arr % num == 0:
return True
else:
return False
다른 풀이
def solution(n):
return n % sum([int(c) for c in str(n)]) == 0
list(map(int, list(str(arr))))대신 [int(c) for c in str(n)]로 간단히 표현할 수 있다!
728x90
'3. 알고리즘 > 프로그래머스' 카테고리의 다른 글
[python] 12. 이상한 문자 만들기(feat. enumerate 함수) (0) | 2021.01.04 |
---|---|
[python] 11. 콜라츠 추측 (0) | 2021.01.03 |
[python] 9. 핸드폰 번호 가리기 (0) | 2021.01.01 |
[python] 8. 정수 제곱근 판별 (0) | 2021.01.01 |
[python] 7. 정수 내림차순으로 배치하기(feat. join 함수) (0) | 2021.01.01 |