2018.10.12 尾递归

尾递归的一种写法:

 

def fun1(n):

    return fun2(n, 1)

def fun2(num, result):

    if num == 1:

        return result

    return fun2(num - 1, num * result)

 

对于这种写法的一种浅显的理解:

第一个自定义函数只负责给第二个自定义函数传参。

第二个自定义函数才负责进行计算。且计算过程全部在函数中完成,return时只进行调用函数。因此不需要堆栈等待上一个函数的运行结果。

 

首先 要明白尾递归的定义。

简单来说,一个函数最后一句代码是调用函数,且仅调用函数。(不能有加减乘除等运算)

那么这个操作就被称为尾调用。

当这个调用为调用自己这个函数时,就被称为尾递归。

(存疑?递归的概念有点模糊,不知道这样说对不对)

 

Q:为什么没有对尾递归优化的语言也会爆栈?

(猜想)对尾递归有优化的函数可以自动释放上一条递归函数的空间。(因为上一条递归函数存在与否对结果不会产生影响)但是没有对尾递归进行优化的语言,则还会继续堆栈。

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值