对于斐波那契数列的计算是计算机算法经典问题,常见的算法有递归算法和非递归算法两种,那么它们之间的不同应该如何对比?
本文用python为例,比较两种不同算法的时间复杂度等不同

  1. 代码比较

递归算法:

 #斐波那契数列的递归算法def fib(index):if index<=1:return 1else:return fib(index-1)+fib(index-2)print(fib(5))

非递归算法:

#斐波那契数列的非递归算法
def fib(index):front=[1,1]if index==0 or index==1:result=1while index>1:result=front[0]+front[1]front[0]=front[1]front[1]=resultindex-=1return result
print(fib(5))

可以比较出相对于递归算法,非递归算法请求的变量似乎相对较多,耗费较多的资源,然而事实并不是如此。
在测试的数值较小的情况下(如同前例index==5),二者差别不大,但是一旦index数量变大,例如80,可以发现递归算法的运行速度明显不如非递归算法,这是为什么呢?

2.原理(时间复杂度分析)
我们先分析非递归算法的时间复杂度 ,由于由index的值决定执行次数,所以index的值n代表其时间复杂度,表示为O(n)
但是使用递归算法,会呈现指数级别的展开,如下所示:

实际上可以得知,这样耗费的系统资源其实更多了,在数量级为10的情况下,展开的节点数量为210-1个,因此这种算法的时间复杂度为O(2n),单单从这个问题出发,递归算法实际上并不是一种好的算法,尽管使用递归使得代码量少,简洁优雅。

在日常编码解决问题时,需要从多个维度思考,不能只是追求代码的美观,以及为了递归而递归,应该具体问题具体分析,使用相对更为高效的算法策略。

计算斐波那契数列递归算法和非递归算法的比较相关推荐

  1. 斐波那契数列 递归与非递归算法实现

    0. 介绍 斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为"兔子数 ...

  2. c语言实现斐波那契数列递归 和 非递归算法

    斐波那契数列规律是从第三个数开始每个数是前两个数的和 递归: #include <stdio.h> int Fibon(int n) {if (n < 0) {printf(&quo ...

  3. 斐波纳契数列递归和非递归算法

    递归的方法定义:  F0=0, F1=1, Fn=F(n-1)+F(n-2)(n>=2,n∈N*) 1.1.2.3.5.8.13.21.-- 所谓Fibonacci数列是指这样一种数列,它的前两 ...

  4. 斐波那契数列——递归与非递归算法时间复杂度分析

  5. 斐波那契的递归算法 c语言,C语言实现斐波那契数列递归和非递归算法

    // c_dataStructure.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include using namespace st ...

  6. 用递归法计算斐波那契数列的第n项

     斐波纳契数列(Fibonacci Sequence)又称黄金分割数列,指的是这样一个数列:1.1.2.3.5.8.13.21.--在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1, ...

  7. 用递归方法计算斐波那契数列(Recursion Fibonacci Sequence Python)

    先科普一下什么叫斐波那契数列,以下内容摘自百度百科: 斐波那契数列(Fibonacci sequence),又称黄金分割数列.因意大利数学家列昂纳多·斐波那契(Leonardoda Fibonacci ...

  8. 使用循环计算斐波那契数列

    1 /* 2 * 使用循环计算斐波那契数列的前 20 项,已经前 20 项的和. 3 提示:斐波那契数列:1,1,2,3,5,8,13,21- 4 从第三项开始,每一项为前面两项的和 5 6 */ 7 ...

  9. python利用列表计算斐波那契数列前30项_python斐波那契数列的计算方法

    题目: 计算斐波那契数列.具体什么是斐波那契数列,那就是0,1,1,2,3,5,8,13,21,34,55,89,144,233. 要求: 时间复杂度尽可能少 分析: 给出了三种方法: 方法1:递归的 ...

  10. C语言 计算斐波那契数列

    C语言 计算斐波那契数列 前言 在学习C语言的道路上多次遇到了求斐波那契数列的问题,今天来总结一下我所知道的几种思想方法. 方法一:循环 使用斐波那契数列的推导式,通过循环将每一个值保存到数组fib中 ...

最新文章

  1. html引入iview如何修改样式,vue中如何修改iView的样式,
  2. selenide小白教程
  3. 开源一个爬取redmine数据的测试报告系统
  4. 基础知识—条件判断语句-switch语句
  5. 任正非:明年应届生招聘人数至少8000人
  6. C++_函数_函数重载注意事项_---C++语言工作笔记035
  7. Linux之操作系统杂谈
  8. tensorflow只训练指定变量
  9. 【转载】Jquery中的$命名冲突的解决方案
  10. python学习记录 - python3.x中如何实现print不换行
  11. 【Gym - 101848D】XOR【多个数异或的典型问题】【费马小定理】
  12. beini安装破*WIFI
  13. 【视频图片网站源码】苹果cmsV10x影视源码[自适应+20个广告位]
  14. 轻灵高效的WizTree树
  15. 有线猫眼监控_如何安装有线监控摄像头系统
  16. Cypress 简介
  17. Gym 100015 B Ball Painting
  18. 你能不能做老大,关键就看这8关!突破了,人人死心塌地追随你
  19. 随机池化(Stochastic Pooling)
  20. ubuntu 主分区扩容

热门文章

  1. ECShop商品详细页 实现尺码颜色关联显示库存数量
  2. device_create 函数详细分析
  3. 轻盈的蜻蜓--newLISP!
  4. 小作坊开发与正规团队开发
  5. 如何解决窗口任务栏有360浏览器闪烁网页广告图标?
  6. keil常见警告、错误处理
  7. 如新:扎根中国,坚守使命,迈向新未来
  8. 使用数据结构中的队列解决舞伴搭配问题
  9. Online Game Development in C++ 第五部分总结
  10. 黄帝内经.素问.宣明五气篇(23)