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 |
Tags
- 알고리즘스터디
- 부스트캠프_AITech_3기
- U_stage
- python3
- 기술면접
- ODQA
- 개인회고
- 파이썬 3
- Level1
- 정렬
- mrc
- 백준
- dfs
- 이진탐색
- 주간회고
- 알고리즘_스터디
- 최단경로
- 백트랙킹
- 이코테
- Level2_PStage
- 구현
- 다시보기
- 프로그래머스
- Level2
- 다이나믹프로그래밍
- 그래프이론
- dp
- 부스트캠프_AITech3기
- 단계별문제풀이
- 그리디
Archives
- Today
- Total
국문과 유목민
31. 하샤드 수 본문
0. 문제
링크) https://programmers.co.kr/learn/courses/30/lessons/12947
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. 짝수와 홀수 (0) | 2020.09.12 |
Comments