剑指Offer面试题:7.斐波那契数列

一题目:斐波那契数列二效率很低的解法很多C/C++/C#/Java语言教科书在讲述递归函数的时候,大多都会用Fibonacci作为例子,因此我们会对这种解法烂熟于心上述递归的解法有很严重的效

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

一 题目:斐波那契数列

题目:写一个函数,输入n,求斐波那契(Fibonacci)数列的第n项。斐波那契数列的定义如下:


剑指Offer面试题:7.斐波那契数列

二 效率很低的解法

  很多C/C++/C#/Java语言教科书在讲述递归函数的时候,大多都会用Fibonacci作为例子,因此我们会对这种解法烂熟于心

#include "stdio.h"
#include <iostream>
using namespace std;

int Fibs(int n)
{
    if (0 == n)
    {
        return 0;
    }
    else if (1 == n)
    {
        return 1;
    }
   return Fibs(n-1) + Fibs(n-2);
}

void main()
{
    cout << "斐波那契数列:" << endl;
    cout <<Fibs(0)<<" ";
    cout <<Fibs(1)<<" ";
    cout <<Fibs(2)<<" ";
    cout <<Fibs(3)<<" ";
    cout <<Fibs(4)<<" ";
    cout <<Fibs(5)<<" ";
    cout <<Fibs(6)<<" ";
    cout <<Fibs(7)<<" ";
    cout <<Fibs(8)<<" " << endl;
    return;
}

剑指Offer面试题:7.斐波那契数列

  上述递归的解法有很严重的效率问题,通过求解第10项的调用过程图来分析:

  剑指Offer面试题:7.斐波那契数列

  从上图中不难发现:在这棵树中有很多结点是重复的,而且重复的结点数会随着n的增大而急剧增加,这意味计算量会随着n的增大而急剧增大。事实上,用递归方法计算的时间复杂度是以n的指数的方式递增的

三 时间复杂度为O(n)的解法

  改进的方法并不复杂。上述递归代码之所以慢是因为重复的计算太多,我们只要想办法避免重复计算就行了。这里的办法是从下往上计算,首先根据f(0)和f(1)算出f(2),再根据f(1)和f(2)算出f(3)……依此类推就可以算出第n项了。很容易理解,这种思路的时间复杂度是O(n)

#include "stdio.h"
#include <iostream>
using namespace std;

int Fibs(int n)
{
    int nFibs = 0;
    if (0 == n)
    {
        return 0;
    }
    else if(1 == n)
    {
        return 1;
    }
    int nSubOne = 1;  // Fibs(n-1)
    int nSubTwo = 0;  // Fibs(n-2)
    for (int i = 2; i <= n; i ++)
    {
        nFibs = nSubOne + nSubTwo;
        nSubTwo = nSubOne;
        nSubOne = nFibs;
    }

    return nFibs;
}

void main()
{
    cout << "斐波那契数列:" << endl;
    cout <<Fibs(0)<<" ";
    cout <<Fibs(1)<<" ";
    cout <<Fibs(2)<<" ";
    cout <<Fibs(3)<<" ";
    cout <<Fibs(4)<<" ";
    cout <<Fibs(5)<<" ";
    cout <<Fibs(6)<<" ";
    cout <<Fibs(7)<<" ";
    cout <<Fibs(8)<<" " << endl;
    return;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/120168.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MySQL窗口函数简介「建议收藏」

    MySQL窗口函数简介「建议收藏」原文地址:https://dev.mysql.com/doc/refman/8.0/en/window-function-descriptions.html#function_last-value译文:12.21.1WindowFunctionDescriptions本节描述非聚合窗口函数,对于查询中的每一行,这些函数使用与该行相关的行执行计算。大多数聚合函数也可以用作窗口函数,…

    2022年10月5日
    2
  • Apache Struts 2入门指南

    Apache Struts 2入门指南ApacheStruts2入门指南作者:chszs,版权所有,未经同意,不得转载。博主主页:http://blog.csdn.net/chszs本文使用最新的Struts2.3.24.1版,演示了怎样用ApacheStruts2构建最基本的Web应用。项目的基本需求:1)Maven3.3.32)EclipseMars.1Release(4.5.1)3)Struts2.3.24

    2022年7月13日
    18
  • 七牛云存储

    七牛云存储

    2021年10月9日
    76
  • keil将程序装入外部FLASH具体解释[通俗易懂]

    keil将程序装入外部FLASH具体解释

    2022年1月30日
    33
  • 使用 video.js 开发 HTML5 视频页面

    使用 video.js 开发 HTML5 视频页面

    2021年9月21日
    54
  • Java学习路线总结(书籍、视频推荐篇)[通俗易懂]

    Java学习路线总结(书籍、视频推荐篇)[通俗易懂]立志存高远,笃行践初心三更灯火五更鸡,正是男儿读书时。黑发不知勤学早,白首方悔读书迟。立志,标定人生方向;奋斗,创造人生价值,二者相辅相成,互相促进。大部分程序员的「目标」都是成为一名优秀的工程师,一名可以统览全局的「架构师」。千里之行始于足下对于大部分普通人而言,成为一名优秀的架构师还是有一定难度的,「千里之行始于足下,一步一个脚印,慢慢来」。????粉丝专属福利:包邮送书3本,如下书单四选一。????获取方式:1、参与文末投票,点赞,收藏即有机会获得精美图书一

    2022年5月16日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号