函数的递归过程

函数的递归就是函数通过自己循环调用自己来完成某项功能,我们在自定义函数的时候也经常会用到递归功能,那么当函数在进行递归的时候内部过程都有哪些呢?

我们以这个程序为例:

age(int n)	
{   int tmp;
   if(n==1)
{ 
return 10;
}
else                        
tmp=age(n-1)+2
return tmp;
}

函数的递归就是函数通过自己循环调用自己来完成某项功能,我们在自定义函数的时候也经常会用到递归功能,那么当函数在进行递归的时候内部过程都有哪些呢?

我们以这个程序为例:

这个程序的递归功能主要是后一项为前一项加2,利用for循环也可以很容易的解决,不过我们不看程序内容只看它运行的过程,假使我们让参数n=4进入函数,先经过if的判断你n=1,执行else,这时候就会面临一个问题:我们并不知道agen-1)的值。于是我们创建一个栈,先将age4)的值置入栈底,然后继续求age3)的值,经过相似的过程后,我们可以将age3)和age2)按顺序置入栈底,完成之后的n就应该等于1了,执行if判断,终于有了第一个返回值10,于是就可以返回age2),将它从栈顶取出并执行后面的语句,得到age2=12,再取出age3),执行函数得到age3=14,取出age4),这时候的栈已经为空,我们就也可以将tmp 返回age4=16了。

具体过程如下图:

 在这个过程中n总共进行了三次递归,递归的进行次数其实是由递归函数的边界所决定的,这个程序中的函数边界就是ifn==1return 10;如果没有递归边界,函数的递归就会一直进行下去,形成一个死循环。

栈的储存也是递归过程中一个十分重要的过程,它的存在使得我们可以保存一些临时变量,同时方便对他们进行取出,不过需要注意的是,栈的大小一般是1MB左右,我们在递归的时候也要注意递归次数的限定。



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值