剑指offer------递归------斐波那契数列

本文介绍斐波那契数列的概念及其递归与非递归两种计算方法。重点对比了递归方法存在的效率问题,并提出了一种通过循环减少重复计算的非递归方法。

题目

大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。(n<=39)

斐波那契数列公式为:

剑指Offer(七):裴波那契数列

思路

这道题递归很好写,但是存在很严重的效率问题。我们以求解f(10)为例类分析递归的求解过程。想求f(10),需要先求得f(9)和f(8)。同样,想求得f(9),需要先求的f(8)和f(7)....我们可以用树形结构来表示这种依赖关系,如下图所示:

剑指Offer(七):裴波那契数列

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

所以,使用简单的循环方法来实现。

代码

1.递归:

class Solution
{
public:
	long long Fibonacci(int n)
	{
		if(n<=0)
			return 0;
		if(n==1)
			return 1;
		
		lpng long third=0;
		
		if(n>=2)
		{
			third=Fibonacci(n-1)+Fibonacci(n-2);
		}
		return third;
	}
};

2.非递归:(保存中间值减少了重复计算)

class Solution
{
public:
	long long Fibonacci(int n)
	{
		if(n<=0)
			return 0;
		if(n==1)
			return 1;
		
		long long first=0,second=1,third=0;
		for(int i=2;i<=n;i++)
		{
			third=first+second;
			first=second;
			second=third;
		}
		return third;
	}
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值