此博客主要用于面试展示,大部分内容为大学|

修竹Kirakira

园龄:2年11个月粉丝:13关注:0

递归

递归

1. 概念

​ 自己调用自己

2. 条件

​ 必须有if退出条件语句,且在递归代码段之前 一般退出条件里是全局变量

3. 递归使用方法

1)函数主要执行代码在递归块之前(和for循环差不多)
2)将函数执行代码放在递归块之后 此方法相当于:到最后一层达到退出条件,返回上一层,再执行代码

普通循环和递归的区别如下

loop循环 recursion递归
循环消耗 CPU 内存
崩溃 死循环不会崩 死递归程序会崩

4. 如果递归函数不传参

​ 以下为递归函数不传参数的几种情况

4.1 全局变量

​ 如果是全局变量的话,使用上述1)方法来递归输出没问题,使用2)方法输出全部一样 (所以退出条件可用全局变量,执行代码不要用)

4.2 栈区局部变量

​ 如果是栈区局部变量的话,可能输出一样的值,因为每一次开栈都会进行初始化(所以退出条件不可用局部变量)

4.3 堆区内存Heap

  1. 如果申请的堆内存首地址在栈上,即int *v1=new int;当递归第二层时,还是会出现b的类似情况,依次递归申请了多个不同的堆内存
  2. 如果申请的堆内存首地址放在全局变量里,和a类似,正递归可以,逆递归不可以

5. 递归函数传参

​ 在使用递归的时候需要传参

类似于二叉树

​ 前序:执行代码在递归之前 正着

​ 中序:执行代码在两个递归中间 中间

​ 后序:执行代码在两个递归之后 倒着

如下为递归传参的示例代码

int Sub_1(int ParameterData)
{
	if(Parameter==3)
	{
		return 3;
	}
	return ParameterData + Sub_1(ParameterData+1);
}
//1+(2+3)

本文作者:修竹Kirakira

本文链接:https://www.cnblogs.com/XiuzhuKirakira/p/17077654.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   修竹Kirakira  阅读(23)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起