Programmers Coding Quiz #12 하샤드 수

김기욱·2021년 2월 2일
0

코딩테스트

목록 보기
12/68

문제 설명

양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.

제한사항

  • x는 1 이상, 10000 이하인 정수입니다.

입출력 예

areturn
10True
12True
11False
13False

풀이

def solution(x):
    checker = sum([int(v) for v in str(x)])
    return x % checker == 0 

이름은 거창하지만 자릿수의 합만 구하면 되는 매우 쉬운문제입니다.
자릿수의 합은 iterable(반복가능)한 str로 정수형을 바꿔준 후 리스트컴프리헨션을 돌리면서 int형으로
바꿔줍니다. map으로 해도 상관은 없겠네요. 그래서 만들어진 리스트의 합이 주어진 정수의 각 자리수의 합입니다.

return에 x % checker(자리수의 합)을 하면 맞으면 True 아니면 False가 나오게 됩니다.

profile
어려운 것은 없다, 다만 아직 익숙치않을뿐이다.

0개의 댓글