C语言求斐波那契数(不考虑溢出)(递归+迭代)

求第n个斐波那契数,斐波那契数事前两个数字相加等于第三个数(1 1 2 3 5 8 13 21 34 55...)

方法一:递归法,这个数列第n个数是前两个数相加之和,我们很容易想到用递归的方法来实现。但是这种方法按照从后往前的方式进行,每个比n小的数相加都需要执行多次,计算地很慢。我们就可以在考虑一下迭代的方法。

cs 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>

//求第n个斐波那契数,斐波那契数事前两个数字相加等于第三个数(1 1 2 3 5 8 13 21 34 55...)
int Fib(int n)
{
	if (n >= 3)
	{
		return Fib(n - 1) + Fib(n - 2);
	}
	else
	{
		return 1;
	}
}

int main()
{
	int n = 0;
	scanf("%d", &n);
	printf("%d \n",Fib(n));
	return 0;
}

方法二:迭代法,按照从小到大的顺序进行,一个数据只计算一次,运算相对较快。

cs 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>

//迭代
int Fib(int n)
{
	int a = 1;
	int b = 1;
	int c = 0;
	while (n >= 3)
	{
		c = a+b;
		a = b;
		b = c;
		n--;
	}
	return c;
}

int main()
{
	int n = 0;
	scanf("%d", &n);
	printf("%d \n", Fib(n));
	return 0;
}
相关推荐
大连好光景1 分钟前
批量匿名数据重识别(debug记录)
开发语言·python
计算机毕设VX:Fegn08951 分钟前
计算机毕业设计|基于Java + vue水果商城系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·课程设计
暴风鱼划水6 分钟前
算法题(Python)哈希表 | 2.两个数组的交集
python·算法·哈希表
清水白石0088 分钟前
《深入 Celery:用 Python 构建高可用任务队列的实战指南》
开发语言·python
fufu031111 分钟前
Linux环境下的C语言编程(四十二)
linux·c语言·算法
Tony Bai12 分钟前
Jepsen 报告震动 Go 社区:NATS JetStream 会丢失已确认写入
开发语言·后端·golang
HalvmånEver15 分钟前
Linux : 基础IO(三)
linux·运维·算法
无敌最俊朗@16 分钟前
STL-list面试剖析(面试复习4)
开发语言
oushaojun216 分钟前
linux中backtrace实战
linux·运维·算法·backtrace
bing.shao18 分钟前
Golang 之 defer 延迟函数
开发语言·后端·golang