计算斐波那契数列递归算法和非递归算法的比较
对于斐波那契数列的计算是计算机算法经典问题,常见的算法有递归算法和非递归算法两种,那么它们之间的不同应该如何对比?
本文用python为例,比较两种不同算法的时间复杂度等不同
- 代码比较
递归算法:
#斐波那契数列的递归算法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),单单从这个问题出发,递归算法实际上并不是一种好的算法,尽管使用递归使得代码量少,简洁优雅。
在日常编码解决问题时,需要从多个维度思考,不能只是追求代码的美观,以及为了递归而递归,应该具体问题具体分析,使用相对更为高效的算法策略。
计算斐波那契数列递归算法和非递归算法的比较相关推荐
- 斐波那契数列 递归与非递归算法实现
0. 介绍 斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为"兔子数 ...
- c语言实现斐波那契数列递归 和 非递归算法
斐波那契数列规律是从第三个数开始每个数是前两个数的和 递归: #include <stdio.h> int Fibon(int n) {if (n < 0) {printf(&quo ...
- 斐波纳契数列递归和非递归算法
递归的方法定义: F0=0, F1=1, Fn=F(n-1)+F(n-2)(n>=2,n∈N*) 1.1.2.3.5.8.13.21.-- 所谓Fibonacci数列是指这样一种数列,它的前两 ...
- 斐波那契数列——递归与非递归算法时间复杂度分析
- 斐波那契的递归算法 c语言,C语言实现斐波那契数列递归和非递归算法
// c_dataStructure.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include using namespace st ...
- 用递归法计算斐波那契数列的第n项
斐波纳契数列(Fibonacci Sequence)又称黄金分割数列,指的是这样一个数列:1.1.2.3.5.8.13.21.--在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1, ...
- 用递归方法计算斐波那契数列(Recursion Fibonacci Sequence Python)
先科普一下什么叫斐波那契数列,以下内容摘自百度百科: 斐波那契数列(Fibonacci sequence),又称黄金分割数列.因意大利数学家列昂纳多·斐波那契(Leonardoda Fibonacci ...
- 使用循环计算斐波那契数列
1 /* 2 * 使用循环计算斐波那契数列的前 20 项,已经前 20 项的和. 3 提示:斐波那契数列:1,1,2,3,5,8,13,21- 4 从第三项开始,每一项为前面两项的和 5 6 */ 7 ...
- python利用列表计算斐波那契数列前30项_python斐波那契数列的计算方法
题目: 计算斐波那契数列.具体什么是斐波那契数列,那就是0,1,1,2,3,5,8,13,21,34,55,89,144,233. 要求: 时间复杂度尽可能少 分析: 给出了三种方法: 方法1:递归的 ...
- C语言 计算斐波那契数列
C语言 计算斐波那契数列 前言 在学习C语言的道路上多次遇到了求斐波那契数列的问题,今天来总结一下我所知道的几种思想方法. 方法一:循环 使用斐波那契数列的推导式,通过循环将每一个值保存到数组fib中 ...
最新文章
- linux系统 长久记录所有用户所有操作记录
- 也谈Hashtable
- IP、TCP和DNS与HTTP的密切关系
- 排列与组合的Java递归实现 (参考)
- いちがつ(2017/1)
- 华策影视:控股股东、实控人等拟合计减持不超4.01%股份
- java xml 合并_Java中合并XML文档的合并
- gnu grub修复_如何修复grub异常
- 稀疏矩阵的加,减,乘,转置
- 深度学习入门:用MNIST完成Autoencoder(续)
- Android开发学习笔记:圆角的Button
- [学习笔记]2020年win10最常用dos命令以及win+R即可运行的命令(使用命令打开自己想要的内容,总比找不到更好,赶快收藏)
- python爬虫气象数据_python爬虫入门,获取全国气象站24小时整点气象数据(二)...
- 音视频入门系列-视频封装格式篇(TS)
- csr蓝牙适配 linux,新款4.0蓝牙适配器 迷你4.0蓝牙适配器 Bluetooth CSR 4.0 Dongle
- Inheritance with Jackson
- 相关性分析【用pythonpandas实现】
- 当a=1,b=2,c=3时,if(ac)b=a;a=c;c=b;的执行结果详解
- PCB如何入门---一些经验与教训
- 4G容量U盘只显示2M多