斐波那契数列

斐波那契数列定义为:


## 效率不高的解法:

long long Fibonacci(unsigned int n)
{
     if (n<=0)
         return 0;

     if (n==1);
         return 1;

     return Fibonacci(n-1) + Fibonacco(n-2);
}
        以求f(10)为例分析递归过程。想求得f(10),需要先求得f(9)和f(8)。同样,想求得f(9),需要先求f(8)和f(7)……如下树形结构来表示这种依赖关系。可以看出,这种递归出现过多的重复求值。当n值很大时,效率明显较低。


##优化的Fibonacci数列求解

long long Fibonacci(unsigned n)
{
    int result[2] = {0,1};
    if(n < 2)
         return rusult[n];

    long long fibNMinusOne = 1;
    long long fibNMiunsTwo = 0;
    long long FibN = 0;
    for(unsigned int i = 2;i<=n;++i)
    {
         fibN = fibNMinusOne + fibNMinusTwo;

         fibNMinusTwo = fibNMinusOne;
         fibNMinusOne = FibN;
    }
    return fibN;
}


这种办法是从下往上计算,现根据f(0)和f(1)就得f(2),再根据f(1)和f(2)求得f(3)……以此类推便可以算出第n项。时间复杂度为O(n)。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值