码迷,mamicode.com
首页 > 其他好文 > 详细

Fibonacci数列递归实现

时间:2019-11-12 16:01:16      阅读:73      评论:0      收藏:0      [点我收藏+]

标签:seq   http   技术   入门   三分   tps   strong   leo   com   

一、什么是Fibonacci数列?

斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波那契数列以如下被以递推的方法定义:F(1)=1,F(2)=1, F(n)=F(n-1)+F(n-2)(n>=3,n∈N*)

由定义可知,这个数列从第3项开始,每一项都等于前两项之和。
参考资料 斐波那契数列_百度百科

二、给出Fibonacci数列的递归表达式。

def fib(n):
return 1 and n <= 2 or fib(n - 1) +fib(n - 2)
print(‘\n the answer is %d‘%(fib(10)))

三、用python或scratch递归实现Fib(n),并进行测试,在你的计算机上1分钟内能计算出fib(10),fib(100),fib(1000),fib(10000)吗?

1.fib(10)

技术图片

用时0.057秒

2.fib(100)

技术图片

如图,在等候了三分多钟依旧无果后,我手动停止了它的运行(因为风扇声实在太大了,跑不动啊!)

3.fib(1000)及fib(10000)

没有尝试,但根据fib(100)的情况来看,应该也跑不动。

四、反击篇!

在参考了下方网站后:
python 入门之斐波那契数列递归表达式算法和非递归算法

此时我发现该网站中所给的非递归算法解决fib(n)的问题很快

而且明白了原因,其原因是:

  • 1.递归算法时间复杂度为:O(2^N)----太耗时间
  • 2.非递归算法时间和空间复杂度都为:O(N)

运行非递归代码计算fib(100)、fib(1000)及fib(10000)

fib(100)

技术图片

fib(1000)

技术图片

fib(10000)

技术图片

Fibonacci数列递归实现

标签:seq   http   技术   入门   三分   tps   strong   leo   com   

原文地址:https://www.cnblogs.com/leo-skr/p/11842551.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!