C语言 计算斐波那契数列

C语言 计算斐波那契数列

前言

在学习C语言的道路上多次遇到了求斐波那契数列的问题,今天来总结一下我所知道的几种思想方法。

方法一:循环

使用斐波那契数列的推导式,通过循环将每一个值保存到数组fib中。需要说明的是,这里的fib[0]表示的是第0项。为了统一,之后的几种方法也是从第0项开始的。

程序如下:

int  n;
int fib[100] = {0,1};  //使用静态数组保存数列
/*
	使用动态数组保存数列
	int* fib = (int *)malloc((n+1)*sizeof(int));
	fib[0] = 0;
	fib[1] = 1;
	使用malloc一定要在程序结束前使用free(),保持一个良好的编程习惯
	free(fib);
*/
scnaf("%d", &n);
for(int i = 1; i <= n; i++)
{
	fib[i] = fib[i - 1] + fib[i - 2];
}

方法二:递归

斐波那契数列的推导式是一个典型的递归式,只要把循环改写成递归的形式就行了

程序如下:

int fib(int i)
{
	if(i <= 1)
	{
		return i;
	}
	else
	{
		return fib(i - 1) + fib(i - 2);
	}
}

方法三:动态规划

fib示意图
直接用递归来求解斐波那契数列的流程如上图所示(以fib(5)为例),不难看出,这里存在着很多的重复计算,极大的影响了计算效率。所以,采用动态规划的编程思想来减少这种不必要的计算。

具体到方法就是将每次计算得到的值用数组保存起来,每次递归调用之前先检查数组中是否有计算得到的值,有的话返回这个值,没有的话再通过递归计算这个值。

程序如下:

int fib(int i, int *a)
{
	if(i<=1)
	{
		return i;
	}
	if(a[i] != 0)
	{
		return a[i];
	}
	else
	(
		a[i] = fib(i-1, a) + fib(i-2, a);
	)
}
int main()
{
	int n;
	scanf("%d",&n);
	//通过malloc创建动态数组,用来保存数列
	int* a = (int *)malloc((n + 1) * sizeof(int));
	a[0] = 0;
	a[1] = 1;
	fib(n, a); // 执行完后,斐波那契数列的前n项都保存到数组a中了
	free(a); //与malloc配套使用
	return 0;
}

方法四:通项公式

前三种方法都是利用斐波那契数列的推导公式(fib N = fib N-1 + fib N-2)计算的,但是如果知道了它的通项公式,则可以利用通项公式直接计算每一项的值。

斐波那契数列的通项公式为:
f i b n = 1 5 [ ( 5 + 1 2 ) n − ( 5 − 1 2 ) n ] fib_n=\frac{1}{\sqrt{5}}[(\frac{\sqrt{5}+1}{2})^n-(\frac{\sqrt{5}-1}{2})^n] fibn=5 1[(25 +1)n(25 1)n]

有兴趣的同学可以自己尝试一下使用通项公式计算,我在此就不展示代码了。

  • 9
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值