알고리즘_코딩테스트/프로그래머스_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. 알고리즘 계획
- 모든 자릿수의 합을 더하는 함수를 하나 만든다. (재귀를 사용)
- 해당 함수를 나눠서 문제를 해결한다.
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. 정리 및 리뷰
- 이전에 다른 사람의 코드에서 배웠던 '자릿수의 합'을 구할 때 사용했던 코드를 사용해봤다.
- 생각한대로 구현해서 만족스러웠으나, 다른 사람의 코드를 보니 좋은 알고리즘은 아니었던 것 같다.
- 그래도 다양한 방법을 시도해보려고 했다는 데에서 의미를 주고자 한다.
코드 만족도: ★★★★☆