국문과 유목민

31. 하샤드 수 본문

알고리즘_코딩테스트/프로그래머스_Level1

31. 하샤드 수

논곰 2020. 9. 12. 22:43

0. 문제

링크) https://programmers.co.kr/learn/courses/30/lessons/12947

 

코딩테스트 연습 - 하샤드 수

양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하�

programmers.co.kr


1. 알고리즘 계획

  1. 모든 자릿수의 합을 더하는 함수를 하나 만든다. (재귀를 사용)
  2. 해당 함수를 나눠서 문제를 해결한다.


2. 나의 코드

def solution(x):
    return x % harshad(x) == 0 

def harshad(num):
    if num < 10:
        return num
    return num%10 + hashad(num//10)


3. 다른 사람의 코드

def solution2(n):
    return n % sum([int(c) for c in str(n)]) == 0

- 리스트 컴프리핸션과 리스트의 sum() 함수를 이용해서 내가 정의했던 새로운 함수를 만들지 않고 식을 간소화시켰다. 


4. 정리 및 리뷰

- 이전에 다른 사람의 코드에서 배웠던 '자릿수의 합'을 구할 때 사용했던 코드를 사용해봤다.

- 생각한대로 구현해서 만족스러웠으나, 다른 사람의 코드를 보니 좋은 알고리즘은 아니었던 것 같다. 

- 그래도 다양한 방법을 시도해보려고 했다는 데에서 의미를 주고자 한다.


코드 만족도: ★★★


'알고리즘_코딩테스트 > 프로그래머스_Level1' 카테고리의 다른 글

33. 행렬의 덧셈  (0) 2020.09.12
32. 핸드폰 번호 가리기  (0) 2020.09.12
30. 평균 구하기  (0) 2020.09.12
29. 콜라즈 추측  (0) 2020.09.12
28. 짝수와 홀수  (0) 2020.09.12
Comments