百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

python使用递归、尾递归、循环三种方式实现斐波那契数列

off999 2024-10-23 12:39 68 浏览 0 评论

在最开始的时候所有的斐波那契代码都是使用递归的方式来写的,递归有很多的缺点,执行效率低下,浪费资源,还有可能会造成栈溢出,而递归的程序的优点也是很明显的,就是结构层次很清晰,易于理解。

可以使用循环的方式来取代递归,当然也可以使用尾递归的方式来实现。

尾递归就是从最后开始计算, 每递归一次就算出相应的结果, 也就是说, 函数调用出现在调用者函数的尾部, 因为是尾部, 所以根本没有必要去保存任何局部变量. 直接让被调用的函数返回时越过调用者, 返回到调用者的调用者去。尾递归就是把当前的运算结果(或路径)放在参数里传给下层函数,深层函数所面对的不是越来越简单的问题,而是越来越复杂的问题,因为参数里带有前面若干步的运算路径。尾递归是极其重要的,不用尾递归,函数的堆栈耗用难以估量,需要保存很多中间函数的堆栈。直接递归的程序中需要保存之前n步操作的所有状态极其耗费资源,而尾递归不需要,尾部递归是一种编程技巧。如果在递归函数中,递归调用返回的结果总被直接返回,则称为尾部递归。尾部递归的函数有助将算法转化成函数编程语言,而且从编译器角度来说,亦容易优化成为普通循环。这是因为从电脑的基本面来说,所有的循环都是利用重复移跳到代码的开头来实现的。如果有尾部归递,就只需要叠套一个堆栈,因为电脑只需要将函数的参数改变再重新调用一次

为了加深对尾递归、递归和循环的对比,这里以斐波那契数列的实现举例:

#!usr/bin/env python 
#encoding:utf-8 
 
''''' 
__Author__:沂水寒城 
功能:尾递归
''' 
 
import time
 
def Fib_recursion(num):
 '''
 直接使用递归法求解斐波那契数量的第num个数字
 '''
 if num<2:
 return num 
 return Fib_recursion(num-1)+Fib_recursion(num-2)
 
 
def Fib_tail_recursion(num,res,temp):
 '''
 使用尾递归法求解斐波那契数量的第num个数字
 '''
 if num==0:
 return res 
 else:
 return Fib_tail_recursion(num-1, temp, res+temp)
 
 
def Fib_circle(num):
 '''
 直接使用循环来求解
 '''
 a=0
 b=1
 for i in range(1,num):
 c=a+b
 a=b
 b=c 
 return c 
 
 
if __name__ == '__main__':
 num_list=[5,10,20,30,40,50]
 for num in num_list:
 start_time=time.time()
 print Fib_recursion(num)
 end_time=time.time()
 print Fib_tail_recursion(num,0,1)
 end_time2=time.time()
 print Fib_circle(num)
 end_time3=time.time()
 print '正在求解的斐波那契数字下标为%s' %num
 print '直接递归耗时为 :', end_time-start_time
 print '尾递归调用耗时为:', end_time2-end_time
 print '直接使用循环耗时为:', end_time3-end_time2
 

结果如下:

5
5
5
正在求解的斐波那契数字下标为5
直接递归耗时为 : 6.38961791992e-05
尾递归调用耗时为: 2.31266021729e-05
直接使用循环耗时为: 1.97887420654e-05
55
55
55
正在求解的斐波那契数字下标为10
直接递归耗时为 : 6.60419464111e-05
尾递归调用耗时为: 3.31401824951e-05
直接使用循环耗时为: 1.8835067749e-05
6765
6765
6765
正在求解的斐波那契数字下标为20
直接递归耗时为 : 0.00564002990723
尾递归调用耗时为: 3.09944152832e-05
直接使用循环耗时为: 2.09808349609e-05
832040
832040
832040
正在求解的斐波那契数字下标为30
直接递归耗时为 : 0.39971113205
尾递归调用耗时为: 1.69277191162e-05
直接使用循环耗时为: 1.19209289551e-05
102334155
102334155
102334155
正在求解的斐波那契数字下标为40
直接递归耗时为 : 39.0365440845
尾递归调用耗时为: 2.19345092773e-05
直接使用循环耗时为: 1.78813934326e-05
12586269025
12586269025
12586269025
正在求解的斐波那契数字下标为50
直接递归耗时为 : 4915.68643498
尾递归调用耗时为: 2.19345092773e-05
直接使用循环耗时为: 2.09808349609e-05

画图图表更加清晰地可以看到差距:

相关推荐

photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
win10下载应用商店(win10应用商店打不开)

1、点击Win10系统的开始菜单,然后在点击应用商店;2、打开Win10应用商店后,在搜索框里输入想要搜索的应用软件,然后点击检索;3、点击搜索到的应用,点击安装;4、点击安装后,系统会提示要切换到这...

dell电脑重装系统win10(dell 重装win10系统)

戴尔笔记本重装系统win10的步骤如下:制作好wepe启动盘之后,将win10系统iso镜像直接复制到U盘。在需要重装系统的戴尔电脑上插入pe启动盘,重启后不停按F12启动快捷键,调出启动菜单对话框,...

android升级包下载安装(android 升级包)

打开手机系统更新升级,前提是官方有新系统推送才能更新  哪个大不一定,但一般规律如下:  1、小版本的更新,通常越更新越大。比如3.1更新到3.2,通常是修复bug,代码量通常会增大,体积就会增大。 ...

hdd硬盘和ssd(ssd硬盘和hdd硬盘是什么意思)

HDD硬盘和SSD硬盘是两种不同类型的电脑存储设备,它们有着以下区别:1.工作原理:HDD硬盘使用机械旋转的磁盘和读写磁头来存储和读取数据,而SSD硬盘则使用闪存存储数据,类似于USB闪存盘。2....

电脑免费软件下载大全(电脑上免费的下载软件)

正常情况下,如果我们想要在自己的电脑上面下载一个不要钱的单机游戏,那么我们是可以直接在我们的软件管理中心进行一个下载的,这个时候我们只需要通过一个权限就能够正常的下载,当然我们也是可以在一些小游戏的软...

mpp文件转换excel(mpp转换成pdf)

要将Excel表格转换为MPP格式,您可以按照以下步骤操作:1.打开Excel表格并确保数据按照项目的不同阶段或任务进行组织。2.将Excel表格中的数据复制到一个新的MicrosoftProj...

win7旗舰版开机密码忘记按f2

方法如下:开始-控制面板-用户帐户;在打开的更改用户帐户界面点击要更改的帐户;然后点击帐户左面的更改密码按钮;在打开的页面上,输入一次当前使用的密码,输入2次要更改的新密码然后保存退出就可以了...

笔记本无音频输出设备(笔记本无音频输出设备)

1、没有声卡驱动,解决方法就是找到笔记本的官网,下载电脑声卡的驱动安装即可。2、没有外界的音频播放设备,解决方法就是买一个外界的音频播放设备插到电脑主机的音频接口上即可。笔记本电脑显示未安装任何音频输...

iso文件能用手机打开吗(iso文件能用手机打开吗安全吗)

一般的压缩软件就可以打开的,比如,好压软件,这个打开只是解压形式的,如果你说的是运行iso文件,这个没有,况且安卓系统也不支持iso运行ISO文件一般用于光盘镜像文件的存储,如果想要在手机上运行ISO...

win7系统卡顿怎么优化(win7很慢很卡怎么优化)

1、首先打开安全卫士,进入安全卫士首页,单击软件窗口右下角的“更多”图标,打开扩展应用程序。2、单击选择“我的工具”。3、在我的工具菜单里面找到“人工服务”单击打开人工服务。4、在人工服务对话框有很多...

如何查看c盘微信聊天记录(如何查看c盘微信聊天记录内存大小)

微信群中的消息只要没删除基本都能保存,想要找微信群中几个多月前的消息可以直接根据日期来查找聊天记录。操作如下:1、打开想要查找记录的微信群,点击右上角人形图标;2、点击查找聊天内容;3、选择按日...

office2016家庭版激活密钥(office家庭版激活码2019)

走淘宝吧,因为零售版的密钥只能用一次。大概几块钱就能激活2016。如果你不在乎钱的话可以向我一样,订阅一个office365.实在不行可以和几个人一起买一个家庭版的365.出现这个情况,找微软申诉是没...

移动硬盘驱动器下载安装(移动硬盘驱动器下载安装教程)

1、右键单击您的桌面,选择“新建文件夹”,并命名该文件夹(例如“usb驱动程序”);2、然后到本站下载驱动程序;3、将其解压缩至在您的桌面上刚刚创建的usb驱动程序文件夹;4、单击开始菜单,然后选择设...

电脑硬盘格式化工具(电脑 格式化硬盘)

硬盘格式化工具很多,PQMACGIG8.0(中文就叫硬盘分区魔法师)是比较好的一个,这个是在WINDOWS下比叫好用,(个人感觉)FDISK也是比较好的一个,这个一般用在DOS下分区格式化WIN...

取消回复欢迎 发表评论: