C++递归

递归
C++函数有一个有趣的特点--可以调用自己,这种功能被称为递归。

包含一个递归调用的递归
如果递归函数调用自己,则被调用的函数也将调用自己,这将无限循环下去,除非代码中包含终止调用链的内容,通常的方法是将递归调用放在if语句中。例如,void类型的递归调用函数recurs()的代码如下:
	void recurs(argumentlist)
	{
		statiments1
		if (test)
			recurs(arguments)
		statements2
	}
test最终将为false,调用链将断开。
递归调用将导致一系列有趣的事件,只要if语句为true,每个recurs()调用都将执行statements1,然后在调用recurs(),而不会执行statements2.当if语句为false时,当前调用将执行statements2.当前调用结束后,程序控制权将返回给调用它的recurs(),而该recurs()将执行其statements2部分,然后结束,并将控制权返回给前一个调用,依次类推。因此,如果recurs()进行了5次递归调用,则第一个statements1部分将按函数被调用的顺序执行5次,然后statements2部分将以与函数调用相反的顺序执行5次,进入5层递归后,程序将沿进入的路径返回。
例如下程序演示:
//recur.cpp--using recursion
#include <iostream>
void countdown(int n);


int main()
{
	countdown(4);
	return 0;
}


void countdown(int n)
{
	using namespace std;
	cout << "counting down..." << n << " (n at " << &n << ")" << endl;
	if (n > 0)
		countdown(n-1);
	cout << n << ": kaboom!" << "        (n at " << &n << ")" << endl;
}

注意,每个递归调用都创建自己的一套变量,因此当程序到达第5次调用时,将有5个独立的n变量,其中每个变量的值都不同。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

书灯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值