티스토리 뷰
문제
번째 피보나치 수를 찾아주는 함수 fib_memo을 작성하기.
fib_memo는 memoization 방식으로 구현한다.
내 코드(통과)
- 엄밀히 얘기하면, 재귀가 아니라 for문을 사용한 것.
- 예를 들어 n 이 8이면 그 전까지의 수들을 계산해서 하나하나 딕셔너리에 넣어준 것이다.
- 이를 재귀함수로 구현할 수 있다.
수정하면 좋을 부분
- def fib(n) 을 수정하는 것이 아니라, fib_memo 함수만 수정해야 한다.
- 사전에 n 이 있으면 그대로 출력하고, 없다면 만들어내는 형식으로 작성한다.
def fib_memo(n, cache):
# 코드를 작성하세요.
if n == 1 or n == 2:
return cache[1]
else:
return cache[n-2] + cache[n-1]
def fib(n):
# n번째 피보나치 수를 담는 사전
fib_cache = {}
fib_cache[1] = 1
fib_cache[2] = 1
if n >= 3:
for i in range(3, n):
fib_cache[i] = fib_cache[i-1] + fib_cache[i-2]
return fib_memo(n, fib_cache)
# 테스트
print(fib(10))
print(fib(50))
print(fib(100))
접근법
- base case의 경우 딕셔너리 들를 필요 없이 바로 1을 리턴
- recursive case의 경우 딕셔너리를 호출하는데, 이때 n 번째 피보나치 수가 계산된 경우와 계산되지 않은 경우로 분리
- cache[n] 이 존재하는 경우: 저장된 값을 바로 리턴한다.
- cache[n] 이 존재하지 않는 경우: 계산을 한 후 chache에 저장하고, 이후 계산한 값을 리턴한다.
수정코드
def fib_memo(n, cache):
# base case
if n < 3:
return 1
# recursive case
# 이미 n번째 피보나치를 계산했다면
# 저장된 값을 바로 리턴한다.
if n in cache:
return cache[n]
# 아직 n번쨰 피보나치수를 계산하지 않았다면
# 계산을 한 후 cache에 저장하고 리턴한다.
cache[n] = fib_memo(n-1, cache) + fib_memo(n-2, cache)
return cache[n]
def fib(n):
# n번째 피보나치 수를 담는 사전
fib_cache = {}
return fib_memo(n, fib_cache)
# 테스트
print(fib(10))
print(fib(50))
print(fib(100))
'Algorithm' 카테고리의 다른 글
[1-2][DP] 거듭제곱 빠르게 구현하기 (0) | 2021.10.12 |
---|---|
[1-1][Brute Force] 투자귀재 규식이1 (0) | 2021.10.12 |
[Programmers][stack/queue] 기능개발 python (211012) (0) | 2021.10.12 |
파이썬 SW문제해결 응용_구현 - 03 탐욕 알고리즘 (0) | 2021.10.06 |
[SWEA][완전탐색] 순열, 조합, 부분집합 (0) | 2021.10.05 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- ssafy합격후기
- ssafy후기
- 개발언어순위
- ssafy결과
- 디즈니얼굴
- SSAFY
- intj여자
- 무료폰트추천
- 개발언어추천
- 개발자
- 개발자커리
- 폰트
- 임대차3법
- 싸피
- 깃허브계정
- 클린코더
- 맥과윈도우로깃허브
- 상업용무료폰트
- 개발도서추천
- 개발자도서추천
- ssafy6기
- 클린코드
- 코딩도서
- 한글무료폰트추천
- 폰트추천
- 싸피6기
- 브왈라
- 개발자로드맵
- 깃허브계정2개
- 개발자책추천
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함