반응형
250x250
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
- MSA
- 오라클
- 학점은행제무료강의
- fastapi
- oracleapex
- 코딩테스트
- it자격증
- 디렉토리계층구조
- SQL
- union
- 학점은행제
- 맥북셋팅
- 프로그래머스
- python
- Homebrew
- 렌탈스튜디오창업
- 개인프로필스튜디오창업
- 컴퓨터공학학사취득
- 모놀리식
- DB
- Pass By Value
- 은행IT
- 계정계
- 의사결정나무모형
- 채널계
- 코어뱅킹
- jdk
- 맥북
- 맥북환경설정
- jdk17
Archives
- Today
- Total
개발머해니
[파이썬] 피보나치 수열 (1) memoization로 구현 - 다이나믹 프로그래밍 ★ 본문
728x90
반응형
실습 설명
n번째 피보나치 수를 찾아주는 함수 fib_memo을 작성해 보세요.
fib_memo는 꼭 memoization 방식으로 구현하셔야 합니다!
실습 결과
# 캐시에 담긴 n번째 피보나치 수를 반환
def fib_memo(n, cache):
#base case
if n <= 2:
return 1
# 캐시에 저장된 피보나치 수가 있으면?
if n in cache:
return cache[n]
# 캐시에 없으면, 캐시에 저장
else:
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))
55
12586269025
354224848179261915075
728x90
반응형
'알고리즘' 카테고리의 다른 글
[파이썬] 피보나치 수열 (3) 공간 최적화 - 다이나믹 프로그래밍 ★ (0) | 2023.09.18 |
---|---|
[파이썬] 피보나치 수열 (2) tabulation로 구현 - 다이나믹 프로그래밍 ★ (0) | 2023.09.18 |
[파이썬] 퀵정렬 (3) 퀵 정렬 더 멋있게 구현하기 - 분할정복 ★ (0) | 2023.09.18 |
[파이썬] 퀵정렬 (2) quicksort 함수 - 분할정복 ★ (0) | 2023.09.17 |
[파이썬] 퀵정렬 (1) partition 함수 - 분할정복 ★ (0) | 2023.09.17 |