- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
斐波那契数列与递归的效率问题
学号算机科学与技术论文C语言中FOR循环与递归的效率问题学生姓名冯冠玺班级计算机科学与技术四班院系计算机学院?摘要: 在多数情况下,C语言中递归由于其易读性(对于新手来说,还有可装逼 性),而比较受到青睐。然而,在一些情况下,递归由于其效率的低下而严重影响到程序的用户体验。关键词:C语言,效率,递归下面通过一个简单的程序来放大这种效率低下的问题:实验平台,工具: 在WIN10的平台下,采用C-free 5.0编译器来编写相应的C程序,直观地凭借输出结果所需时间来比较递归与for循环的效率。//该程序是求斐波那契数列第n个数的值#includestdio.hint digui(int n){if(n==1||n==2) return 1;else return (digui(n-1)+digui(n-2)); }int main(){int a;scanf(%d,a);printf(%d,digui(a));}经过测试,当n在37之后,开始出现人眼可观的明显卡顿。//通过FOR循环来计算#includestdio.hint main(){int a[100]={1,1},i,n;scanf(%d,n);if(n==1||n==2) printf(%d,a[n-1]);if(n=3){ for(i=2;in;i++) a[i]=a[i-1]+a[i-2]; printf(%d,a[i-1]); }}经测试,在int整形数据类型所能输出的数字范围内(即n小于等于48),无任何卡顿。那么为什么会出现这样的情况?许多问题是以递归的形式进行解释的,这只是因为它比非递归形式更为清晰。但是,这些问题的迭代实现往往比递归实现效率更高,虽然代码的可读性可能稍差一些,当一个问题相当复杂,难以用迭代形式实现时,此时递归实现的简洁性便可以补偿它所带来的,运行时开销。然而,对于极端的情况(斐波那契数列),它使用递归步骤计算digui(n-1)和digui(n-2)。但是,在计算digui(n-1)时也将计算digui(n-2)。每个递归调用都触发另外两个递归调用,而这两个调用的任何一个还将触发两个递归调用,再接下去的调用也是如此。这样,冗余计算的数量增长得非常快。例如,在递归计算digui(10)时,digui(3)的值被计算了21次。但是,在递归计算 digui(30)时,digui(3)的值被计算了317811次。当然,这317811次计算所产生的结果是完全一样的,除了其中之一外,其余的纯属浪费。这个额外的开销是相当恐怖的!总结: 在编程时,具体问题要具体分析,有时递归的高度简洁与可读性可以一定程度上弥补自身效率低下的问题,然而决不能死套递归,要多多考虑更高效的算法。
您可能关注的文档
最近下载
- 制定手机使用协议书.docx VIP
- 隐形矫正培训课件.pptx VIP
- 2025年高考化学一轮复习:物质的分类及转化(讲义)解析版.pdf VIP
- 2023中华护理学会团体标准-老年人误吸的预防.pptx VIP
- 《Rubis软件2017版》操作手册.pdf VIP
- 标准图集-08CJ17快速软帘卷门 透明分节门 滑升门 卷帘门.pdf VIP
- 消化内科-病历讨论.pptx VIP
- (⼈教2019版)化学 选必1 第三单元 水溶液中的离子反应与平衡 大单元教学设计.docx
- SHT 3525-2015 石油化工低温钢焊接规范.pdf VIP
- Q/CRRC J26-2018- 轨道交通装备产品禁用和限用物质.pdf VIP
文档评论(0)