a和b分别代表当前项前面的第2项和第1项 a=b=1; //给a和b赋初值1 if(n==1||n==2) return 1; else for(int i=3;i<=n;i++){ c=a+b; //求出当前项 a=b;//把前面第1项赋给前面第2项 b=c;//把当前项赋给前面第1项 } return c;//返回所求的第n项 }
b i);i=j;j=k;n++;}} 输入一个数n 求前n个fibonacci数
|||
递归:long Fib(int n) { if(n==1||n==2) //终止递归条件 return 1; else return Fib(n-1)+Fib(n-2); } 非递归: long Fib1(int n) { int a &l); while(n<=l) {k=i+j;printf("%d " n=1; scanf("%d" l k=1 j=1 i);i=j;j=k;n++;}} #include<stdio.h>int main(){ int i=0 &l); while(n<=l) {k=i+j;printf("%d " n=1; scanf("%d" l k=1 j=1 a2=1;int an ;for(int i=3;i<n;i++){an=a1+a2;a1=a2;a2=an;}return an;}
|||
#include<stdio.h>int main(){ int i=0
递归:int Fibo(int n){if(n==1 || n==2)return 1 ;else return Fibo(n-1)+Fibo(n-2) ;}
答案补充
非递归:int Fibo(int n){if(n==1||n==2)return 1 ;int a1=1 c;//C代表当前项
求fibonacci数列(递归+非递归)
最新推荐文章于 2022-08-19 19:51:29 发布
本文介绍了两种生成斐波那契数列的方法:递归法和非递归法。递归法通过重复调用自身来计算数列中的每一项;非递归法则使用循环结构,效率更高。此外,还提供了C语言实现代码。
3217

被折叠的 条评论
为什么被折叠?



