计算斐波那契数列中的第n个数

斐波那契数列

Fibonacci数列中的每个数都是其两个直接前项的和。0,1,1,2,3,5,8,13,21,......

可以递归定义Fibonacci数列:


Fibonacci数列的数的增长速度几乎与2的幂增长的速度相当。但是我们需要一个Fibonacci数列中第n个数的算法:

第一种算法:指数算法


这种算法是直接由Fibonacci数列的递归定义转变来的,时间复杂度也是相应的指数级别的。函数T(n)代表fib1计算的基本操作次数:


这样我们就会发现:这也就是说基本操作的个数也是随着指数基本的增长,为什么这个算法这么慢呢?

我们来理解一下算法的执行过程。我们发现,在计算过程中,fib1算法计算了很多重复的节点值。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值