曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 1895|回复: 0
打印 上一主题 下一主题

循环与递归

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34387
跳转到指定楼层
楼主
发表于 2015-8-25 11:32:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
实际上,从理论上来说,所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰。

使用递归需要注意的一个地方是要防止栈溢出。因为函数调用是通过栈这种数据结构来实现的,每当进入一个函数调用,栈就会加一层栈帧,而当函数返回时,栈就会减少一层栈帧。由于栈的大小不是无限的,所以递归调用的次数过多,就会导致栈溢出。

解决递归调用栈溢出的方法是通过尾递归来优化,事实上尾递归和循环的效果是一样的,因此把循环堪称是一种特殊的尾递归函数也是可以的。

尾递归是指,在函数返回的时候,调用自身本身,并且 return 语句不能包含表达式。这样,编译器或者解释器就可以把尾递归做优化,使递归本身不论调用多少次,都只占用一个栈帧,不会出现栈溢出的情况。遗憾的是,大多数的编程语言并没有对尾递归做优化。

尾递归 python 举例:
[Python] 纯文本查看 复制代码
def fact_iter(num, product):
    if num == 1:
        return product
    return fact_iter(num - 1, num * product)

上面,fact_iter(num - 1, num * product) 仅返回递归函数本身,num-1 和 num * product 在函数调用前就会被计算,不影响函数调用。如果最后是 return n * fact(n - 1) 这种含有表达式的写法,就是不尾递归了。


您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-6-17 10:20 , Processed in 0.065364 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表