原文: https://www.programiz.com/cpp-programming/recursion

在本教程中,我们将通过示例学习 C++ 中的递归函数及其工作。

调用自身的函数被称为递归函数。 并且,这种技术称为递归。


C++ 中的递归工作原理

  1. void recurse()
  2. {
  3. ... .. ...
  4. recurse();
  5. ... .. ...
  6. }
  7. int main()
  8. {
  9. ... .. ...
  10. recurse();
  11. ... .. ...
  12. }

下图显示了递归调用的方式。

C   递归 - 图1

C++ 编程中递归的工作方式

递归一直持续到满足某些条件为止。

为了防止无限递归,可以在一个分支进行递归调用而另一个不进行递归调用的情况下使用if...else语句(或类似方法)。


示例 1:使用递归的数字阶乘

  1. // Factorial of n = 1*2*3*...*n
  2. #include <iostream>
  3. using namespace std;
  4. int factorial(int);
  5. int main() {
  6. int n, result;
  7. cout << "Enter a non-negative number: ";
  8. cin >> n;
  9. result = factorial(n);
  10. cout << "Factorial of " << n << " = " << result;
  11. return 0;
  12. }
  13. int factorial(int n) {
  14. if (n > 1) {
  15. return n * factorial(n - 1);
  16. } else {
  17. return 1;
  18. }
  19. }

输出

  1. Enter a non-negative number: 4
  2. Factorial of 4 = 24

递归程序的工作原理

C   递归 - 图2

C++ 递归程序如何工作

如我们所见,factorial()函数正在调用自身。 但是,在每次通话期间,我们将n的值减小了1。 当n小于1时,factorial()函数最终返回输出。


递归的优缺点

以下是在 C++ 中使用递归的优缺点。


C++ 递归的优点

  • 它使我们的代码更短,更清晰。
  • 在涉及数据结构和高级算法(例如图形和树遍历)的问题中需要递归。

C++ 递归的缺点

  • 与迭代程序相比,它占用大量栈空间。
  • 它使用更多的处理器时间。
  • 与等效的迭代程序相比,调试起来会更加困难。