C++中的递归函数是一种调用自身的函数。递归函数通常用于解决那些可以通过将问题分解为更小规模的相同问题来解决的问题。要编写递归函数,请遵循以下步骤:
以下是一个C++递归函数的示例,用于计算阶乘:
#include <iostream>
// 基本情况:0的阶乘和1的阶乘都是1
int factorial_base_case() {
return 1;
}
// 递归情况:n的阶乘等于n乘以(n-1)的阶乘
int factorial_recursive_case(int n) {
if (n == 0 || n == 1) {
return factorial_base_case();
} else {
return n * factorial_recursive_case(n - 1);
}
}
int main() {
int number = 5;
std::cout << "The factorial of " << number << " is: " << factorial_recursive_case(number) << std::endl;
return 0;
}
在这个例子中,factorial_recursive_case
函数是递归函数,它首先检查基本情况(当n
为0或1时),然后调用自身计算较小规模的阶乘。