递归 和 迭代 斐波那契数列

本文介绍了一种使用C语言实现斐波那契数列的方法,包括递归及迭代两种方式。通过递归函数Fbi(int i)计算斐波那契数列,并通过迭代填充数组来展示数列。该程序能够输出前40项斐波那契数列。

 



#include "stdio.h" int Fbi(int i) /* 斐波那契的递归函数 */ { if( i < 2 ) return i == 0 ? 0 : 1; return Fbi(i - 1) + Fbi(i - 2); /* 这里Fbi就是函数自己,等于在调用自己 */ } int main() { int i; int a[40]; printf("迭代显示斐波那契数列:\n"); a[0]=0; a[1]=1; printf("%d ",a[0]); printf("%d ",a[1]); for(i = 2;i < 40;i++) { a[i] = a[i-1] + a[i-2]; printf("%d ",a[i]); } printf("\n"); printf("递归显示斐波那契数列:\n"); for(i = 0;i < 40;i++) printf("%d ", Fbi(i)); return 0; }

 

转载于:https://www.cnblogs.com/2014acm/p/7632927.html

非常好的问题!斐波那契数列是由0、1开始,后面的每一项都是前两项的。所以斐波那契数列的前几项如下: 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144... 接下来,我会先讲解如何用递归实现斐波那契数列的第n项,然后再介绍如何用迭代实现。 递归实现 递归实现斐波那契数列的思路很简单:对于斐波那契数列的第n项,我们可以先求出第n-1n-2项,然后将它们相加即可。而对于第n-1n-2项,我们同样可以用同样的方式求出。 根据递归的思路,我们可以定义一个递归数,码如下: int fibonacci_recursion(int n) { if (n <= 0) return 0; else if (n == 1) return 1; else return fibonacci_recursion(n-1) + fibonacci_recursion(n-2); // 递归调用 } 上面的码先判断了一下n的值是否小于等于0或等于1,这是为了避免递归陷入无限循环。如果n等于0,则返回0;如果n等于1,则返回1。否则,我们将递归调用fibonacci_recursion(n-1)fibonacci_recursion(n-2),并将它们相加返回。 但是,这个递归实现有一个很明显的问题:当n比较大时,递归会变得非常的深,这会导致数调用栈溢出。因此,我们需要用迭代来替递归迭代实现 迭代实现斐波那契数列的思路与递归实现基本一致,只是用循环替递归。我们首先初始化前两项为01,并用循环依次计算出后面的每一项。 具体实现如下: int fibonacci_iteration(int n) { if (n <= 0) return 0; else if (n == 1) return 1; int a = 0, b = 1, c; for (int i = 2; i <= n; i++) { c = a + b; a = b; b = c; } return b; } 上面的码中,我们先判断了一下n的值,如果n等于0,则返回0,如果n等于1,则返回1。然后,我们用a初始化为0,b初始化为1,依次计算出后面的每一项。具体实现如下: - 首先,我们将ab的值相加,将结果赋值给变量c。 - 然后,将b的值赋给a,将c的值赋给b。 - 最后,当i>n时,返回变量b即可。 这个迭代实现的想法很简单,而且循环的次数只有n-1次,因此它是比递归实现更加高效的一种实现方法。 总结 斐波那契数列是一道经典的算法题,也是算法程序设计中很重要的一个概念。我们用递归迭代分别实现了斐波那契数列的第n项,递归实现简单,但会导致数调用栈溢出;迭代实现思路相对复杂,但是效率更高,不会出现数调用栈溢出的问题。我希望我的回答能够帮助你更好地理解斐波那契数列
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值