메모화로 재귀 함수의 효율성 높이기
재귀 함수는 자기 자신을 호출하는 함수로, 같은 계산을 반복하게 되어 성능이 저하될 수 있습니다.
이러한 문제점을 해결하기 위해 메모화(Memoization)
기법이 사용됩니다.
메모화란?
메모화는 함수의 반환 값을 저장해 두었다가, 같은 입력에 대해 함수를 다시 호출할 때 저장된 값을 반환하는 기법입니다.
메모화를 사용하면 함수의 반환 값을 저장해 두어 중복 계산을 방지하고, 함수의 실행 속도를 높일 수 있습니다.
메모화를 사용한 피보나치 수열 예시
def fibonacci(n): # 메모이제이션에 사용할 빈 딕셔너리 생성 memo = {} def helper(x): # 이미 계산된 값이 있으면 저장된 값을 반환 if x in memo: return memo[x] # 종료 조건: 0 또는 1일 때 x 반환 if x <= 1: return x # 계산 결과를 메모이제이션 딕셔너리에 저장 memo[x] = helper(x - 1) + helper(x - 2) return memo[x] # 재귀 함수 호출 return helper(n) # 10번째 피보나치 수열 값 출력 print(fibonacci(10)) # 55
위 코드에서 memo
딕셔너리를 사용해 이전에 계산한 값을 저장하고, 이미 계산한 값이라면 저장된 값을 반환합니다.
딕셔너리에 담기는 값은 아래와 같은 n
에 대한 피보나치 수열의 결과입니다.
memo 딕셔너리
{ 2: 1, 3: 2, 4: 3, 5: 5, 6: 8, 7: 13, 8: 21, 9: 34, 10: 55 }
메모화를 사용하면 함수의 실행 속도를 높일 수 있으며, 중복 계산을 방지해 성능을 향상시킬 수 있습니다.
하지만 계산 결과를 저장해 두기 위한 추가적인 메모리가 필요하므로, 메모화를 사용할 때는 메모리 사용량에 주의해야 합니다.
Mission
0 / 1
메모화(memoization)
의 주된 목적은 무엇인가요?
재귀 함수의 종료 조건을 설정하기 위해
재귀 함수의 호출 횟수를 줄이기 위해
동일한 계산의 반복을 피하기 위해
재귀 함수를 비재귀 함수로 변환하기 위해
학습 자료
AI 튜터
배포
디자인
업로드
수업 노트
즐겨찾기
도움말
코드 에디터
코드 실행
코드 생성
실행 결과