>백엔드 개발 >파이썬 튜토리얼 >Python은 꼬리 재귀 최적화를 수행합니까?

Python은 꼬리 재귀 최적화를 수행합니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-07 19:08:14454검색

Does Python Perform Tail Recursion Optimization?

Python의 꼬리 재귀 최적화

Python은 꼬리 재귀를 최적화하지 않습니다. 이는 Guido van Rossum이 다음과 같은 이유로 꼬리 재귀를 구현하지 않기로 명시적으로 결정한 것으로 확인되었습니다. 적절한 보존 Tracebacks.

질문: Python에서 꼬리 재귀 최적화가 가능합니까?

답변: 아니요.

토론 :

문제를 설명하려면 다음을 고려하세요. 삼각 계열의 합을 계산하는 다음 Python 코드:

def trisum(n, csum):
    if n == 0:
        return csum
    else:
        return trisum(n - 1, csum + n)

n에 대해 큰 값을 사용하여 실행하면 이 코드는 과도한 재귀 깊이로 인해 실패합니다. 꼬리 재귀 최적화는 재귀 호출을 업데이트된 매개변수가 있는 함수의 시작 부분으로 점프하는 것으로 대체함으로써 이 문제를 완화할 수 있습니다.

그러나 Guido van Rossum이 적절한 역추적 유지를 우선시했기 때문에 Python은 꼬리 재귀 최적화를 구현하지 않습니다.

최적화 해결 방법:

꼬리 재귀 최적화인 경우 원하는 경우 Python 코드를 수동으로 변환하여 재귀를 제거할 수 있습니다. 다음은 trisum 함수의 수정된 버전입니다.

def trisum(n, csum):
    while True:                     # Change recursion to a while loop
        if n == 0:
            return csum
        n, csum = n - 1, csum + n   # Update parameters instead of tail recursion

위 내용은 Python은 꼬리 재귀 최적화를 수행합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.