Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 부스트캠프_AITech3기
- Level2
- 다시보기
- 구현
- mrc
- 부스트캠프_AITech_3기
- python3
- 단계별문제풀이
- 이코테
- 최단경로
- 백트랙킹
- 기술면접
- 개인회고
- 글또
- 그래프이론
- 프로그래머스
- U_stage
- Level2_PStage
- ODQA
- 파이썬 3
- 그리디
- 알고리즘스터디
- 백준
- 알고리즘_스터디
- 이진탐색
- dfs
- 주간회고
- dp
- Level1
- 정렬
Archives
- Today
- Total
국문과 유목민
31. 하샤드 수 본문
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. 정리 및 리뷰
- 이전에 다른 사람의 코드에서 배웠던 '자릿수의 합'을 구할 때 사용했던 코드를 사용해봤다.
- 생각한대로 구현해서 만족스러웠으나, 다른 사람의 코드를 보니 좋은 알고리즘은 아니었던 것 같다.
- 그래도 다양한 방법을 시도해보려고 했다는 데에서 의미를 주고자 한다.
코드 만족도: ★★★★☆
'알고리즘_코딩테스트 > 프로그래머스_Level1' 카테고리의 다른 글
33. 행렬의 덧셈 (0) | 2020.09.12 |
---|---|
32. 핸드폰 번호 가리기 (0) | 2020.09.12 |
30. 평균 구하기 (0) | 2020.09.12 |
29. 콜라즈 추측 (0) | 2020.09.12 |
28. 짝수와 홀수 (1) | 2020.09.12 |