小编Meh*_*edi的帖子

如何更快地生成Fibonacci

我是一名CSE学生,正准备参加编程竞赛.现在我正在研究Fibonacci系列.我有一个大小约为包含正整数的Kilo字节的输入文件.输入甲酸酯看起来像

3 5 6 7 8 0
Run Code Online (Sandbox Code Playgroud)

零表示文件结束.输出应该如此

2 
5 
8 
13 
21 
Run Code Online (Sandbox Code Playgroud)

我的代码是

#include<stdio.h>

int fibonacci(int n) {
  if (n==1 || n==2)
    return 1;
  else
    return fibonacci(n-1) +fibonacci(n-2);
}
int main() {
  int z;
  FILE * fp;    
  fp = fopen ("input.txt","r");    
  while(fscanf(fp,"%d", &z) && z) 
   printf("%d \n",fibonacci(z));
  return 0;
}
Run Code Online (Sandbox Code Playgroud)

该代码适用于样本输入并提供准确的结果但问题是我的实际输入集它花费的时间超过我的时间限制.谁能帮我吗.

c algorithm fibonacci

13
推荐指数
6
解决办法
3万
查看次数

标签 统计

algorithm ×1

c ×1

fibonacci ×1