鱼C论坛

 找回密码
 立即注册
查看: 1234|回复: 4

[已解决]迭代与递归运行速度不同的原因?

[复制链接]
发表于 2018-1-10 21:38:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
迭代斐波那契数列

def fab(n):
    n1 = 1
    n2 = 1
    n3 = 1
#先默认n3的初始值为 1
    if n < 1:
        print('输入有误!')
        return -1

    while(n-2)>0:
        n3 = n2 + n1
        n1 = n2
        n2 = n3
        n -= 1
# n -= 1--------代表 n = n - 1 ------- 代表循环次数减1
    return n3

result = fab(35)
if result != -1:
    print('总共有%d对小兔子诞生!'%result)


递归斐波那契数列
def fab(n):
    if n < 1:
        print('输入有误!')
        return -1

    if n == 1 or n == 2:
        return 1
    else:
        return fab(n-1) + fab(n-2)

result = fab(35)
if result != 1:
    print('%d 的斐波那契数列是:%d'%(number, result))




问题,为什么,用迭代写的代码跑起来比递归方法写的要快很多?
最佳答案
2018-1-10 21:49:08
迭代要一层层的将数据压入堆栈,再逆向逐级返回,占用大量内存,效率上比递归要低很多。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-1-10 21:49:08 | 显示全部楼层    本楼为最佳答案   
迭代要一层层的将数据压入堆栈,再逆向逐级返回,占用大量内存,效率上比递归要低很多。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-10 21:49:21 | 显示全部楼层
可能是因为递归占用内存更多吧,计算起来,要挂起很多程序
而迭代就是正常的运行,只有一个在跑,肯定快些
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-1-11 08:03:15 | 显示全部楼层
冬雪雪冬 发表于 2018-1-10 21:49
迭代要一层层的将数据压入堆栈,再逆向逐级返回,占用大量内存,效率上比递归要低很多。

非常专业,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-1-11 08:03:50 | 显示全部楼层
影-死神 发表于 2018-1-10 21:49
可能是因为递归占用内存更多吧,计算起来,要挂起很多程序
而迭代就是正常的运行,只有一个在跑,肯定快些

通俗易懂,深入浅出,感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-30 21:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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