原题链接:C语言训练-斐波纳契数列
菲波那切数列用递归的方式效率是相当低下的,一般用迭代。但是为了学习,两种方法都写出来吧。
参考代码如下:
1 迭代方式
#include <stdio.h>
#include <string.h>
long fibonacci(int n)
{
if (n <= 2)
{
return 1;
}
long result;
long pre_result;
long pre_pre_result;
pre_result = pre_pre_result = 1;
while (n > 2)
{
result = pre_result + pre_pre_result;
pre_pre_result = pre_result;
pre_result = result;
n--;
}
return result;
}
int main()
{
int N;
scanf("%d", &N);
int i;
for (i = 1; i <= N; i++)
{
printf("%ld ", fibonacci(i));
}
return 0;
}2 递归方式
#include <stdio.h>
#include <string.h>
long fibonacci(int n)
{
if (n <= 2)
return 1;
return fibonacci(n - 1) + fibonacci(n - 2);
}
int main()
{
int N;
scanf("%d", &N);
int i;
for (i = 1; i <= N; i++)
{
printf("%ld ", fibonacci(i));
}
return 0;
}0.0分
24 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
#include<stdio.h> int main(){ int a=1,b=0,c=0,s,i=0; scanf("%d",&s); while(1){ printf("%d ",a); b=a+c; i++; if(i==s)return 0; printf("%d ",b); c=a+b; i++; if(i==s)return 0; printf("%d ",c); a=c+b; i++; if(i==s)return 0; } return 0; }#include<stdio.h> int main() { int N,i,j,k,m; scanf("%d",&N); if(N==1) { printf("1 "); } if(N<41) { printf("1 "); for(i=0,j=1,k=1;k<N;k++) { printf("%d ",i+j); m=j; j=i+j; i=m; } } return 0; }#include <stdio.h> #include <stdlib.h> #include <math.h> #include <string.h> int main() { int a=1,b=1,c; int num; scanf("%d",&num); if(num==1) printf("1"); else{ int i; printf("1 1 "); for(i=0;i<num-2;i++){ c=a+b; printf("%d ",c); a=b; b=c;} } }