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;
}
相关推荐
ONE_PUNCH_Ge22 分钟前
Go 语言变量
开发语言
幼稚园的山代王23 分钟前
go语言了解
开发语言·后端·golang
奔跑吧邓邓子26 分钟前
【C语言实战(8)】C语言循环结构(do-while):解锁编程新境界
c语言·实战·do-while
晚风残31 分钟前
【C++ Primer】第六章:函数
开发语言·c++·算法·c++ primer
小莞尔41 分钟前
【51单片机】【protues仿真】基于51单片机温度测量系统
c语言·单片机·嵌入式硬件·物联网·51单片机
杨云强41 分钟前
离散积分,相同表达式数组和公式
算法
地平线开发者42 分钟前
征程 6 | BPU trace 简介与实操
算法·自动驾驶
满天星83035771 小时前
【C++】AVL树的模拟实现
开发语言·c++·算法·stl
晓风凌殇1 小时前
单片机按键检测与长短按识别实现
c语言·单片机
weixin_456904271 小时前
基于.NET Framework 4.0的串口通信
开发语言·c#·.net