递归

递归

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)

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

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    递归

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/383660

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月8日 下午6:24
下一篇 2023年3月8日 下午6:26

相关推荐