함수가 자신을 호출하는 과정을 재귀라고 하며
해당 함수를 재귀 함수라고 합니다.
컴퓨터 프로그래밍은 수학의 기본적인 응용이므로
먼저 재귀 뒤에 숨어 있는 수학적 추론을 이해하려고 노력합니다.
일반적으로 우리 모두는 함수의 개념을 알고 있습니다. 간단히 말해서 함수는
입력을 제공할 때 출력을 생성하는 수학 방정식. 예를 들어:
함수 F(x)가 다음과 같이 정의된 함수라고 가정합니다. F(x) = x^2 4
이 함수에 대한 Java 코드를 다음과 같이 작성할 수 있습니다.
반환 (x * x 4);
}
따라서.
재귀로 넘어가기 전에, 또 다른 수학적
을 이해해 봅시다.
수학적 귀납법(PMI).로 알려진 개념
공식, 또는 일련의 자연수에 대해 주장되는 정리. 그것은
다음 세 단계를 따릅니다:
1.** 사소한 경우의 단계*
: 이 단계에서는 에 대해 원하는 명령문을 증명합니다.
n = 0 또는 n = 1과 같은 기본 사례입니다.
2.
* 가정 단계**: 이 단계에서는 원하는 진술이
n = k에 유효합니다.
S(N): 1 2 3 ... N = (N * (N 1))/2
(처음 N개의 자연수의 합)
증거:
1단계: N = 1인 경우 S(1) = 1이 참입니다.
2단계: 주어진 진술이 N = k에 대해 참이라고 가정합니다. 즉,
1 2 3 .... k = (k * (k 1))/2
3단계: 2단계를 사용하여 N = k 1에 대한 명제를 증명해 보겠습니다.
증거:
1 2 3 ... (k 1) = (k*(k 1))/2 (k 1)
1 2 3 ... (k 1) = (k 1)*((k 2)/2)
1 2 3 ... (k 1) = ((k 1)*(k 2))/2
따라서 증명되었습니다.
단계:
● 기본 사례: 재귀 함수에는
종료 조건이 있어야 합니다.
프로세스 자체 호출이 중지됩니다. 이러한 경우를 기본 사례라고 합니다. 기본 사례가 없으면 계속 자신을 호출하고
오류에 갇히게 됩니다.
무한 루프. 곧 재귀 깊이*가 초과되어
가 발생합니다.
오류가 발생했습니다.
● 재귀 호출: 재귀 함수는 더 작은 버전에서 자체적으로 호출됩니다
주요 문제의. 이 단계를 그대로 작성할 때 주의가 필요합니다
작은 문제가 무엇인지 정확하게 파악하는 것이 중요합니다.
● 소규모 계산: 일반적으로 각 재귀
에서 계산 단계를 수행합니다.
부르다. 재귀 호출 전후에 이 계산 단계를 수행할 수 있습니다
문제의 성격에 따라 다릅니다.
참고: 재귀는 재귀 호출을 저장하는 내장 스택을 사용합니다. 따라서
메모리 오버플로를 방지하려면 재귀 호출 수를 가능한 한 줄여야 합니다. 만약에
재귀 호출 횟수가 최대 허용량을 초과했습니다.
**재귀 깊이
**가 초과됩니다.
이제 재귀
를 사용하여 몇 가지 일반적인 문제를 해결하는 방법을 살펴보겠습니다.
접근법: PMI의 3단계를 파악한 후
를 사용하여 동일한 단계를 연관시킵니다.
재귀
int ans = 사실(n-1); #가정 단계
ans * n을 반환합니다. #가정 단계부터 문제 해결
}
이것을 기본 케이스로 유지하세요. 따라서 코드는 이제 다음과 같습니다:
if (n == 0) // 기본 사례
1을 반환;
또 다른
n*factorial(n-1)을 반환합니다. // 재귀적 사례
}
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3