【剑指offer】面试题9:斐波那契数列

不管现实多么惨不忍睹,都要持之以恒地相信,这只是黎明前短暂的黑暗而已。不要惶恐眼前的难关迈不过去,不要担心此刻的付出没有回报,别再花时间等待天降好运。真诚做人,努力做事!你想要的,岁月都会给你。【剑指offer】面试题9:斐波那契数列,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

题目:写一个函数,输入n,求斐波那契数列的第n项。

方法1:递归。缺点:如果n比较大,那么递归程度比较深

方法2首先根据f(0)和f(1)计算出f(2),再根据f(1)和f(2)算出f(3),以此类推……
            时间复杂度O(n) 

代码如下:

#include<iostream>
using namespace std;

//使用递归的方法实现斐波那契数列,重复计算太多节点的值 
int Fib_Recursion(int n)  
{
	if(n==0)
	    return 0;
	if(n==1)
	    return 1;
    return  Fib_Recursion(n-1)+Fib_Recursion(n-2);
	
}

//更为简单的方法,首先根据f(0)和f(1)计算出f(2),再根据f(1)和f(2)算出f(3),以此类推……
//时间复杂度O(n) 
int Fib_New(int n)
{
	int result[2]={0,1};
	if(n<2)
	    return result[n];
	
	int fibMinus1=1;  // Fib(n-1)
	int fibMinus2=0;  // Fib(n-2)
	int fibN=0;       // 我们要求的Fib(N)
	
	for(int i=2;i<=n;i++)
	{
		fibN=fibMinus1+fibMinus2;
		fibMinus2=fibMinus1;
		fibMinus1=fibN;
	}
	return fibN;
}

int main()
{
	int n;
	cin>>n;

	cout<<Fib_Recursion(n)<<endl;
	cout<<Fib_New(n)<<endl;
	
	return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/162922.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!