标签:
Fibonacci数列,定义如下:
f(1)=f(2)=1
f(n)=f(n-1)+f(n-2) n>=3
计算第n项Fibonacci数值。
输入第一行为一个整数n(1<=n<=10000)。
输出对应的f(n)。
1 #include <iostream> 2 #include <cstring> 3 #include <cstdio> 4 using namespace std; 5 #define len 100000000 6 int a[10001][1000]; 7 int main() 8 { 9 int n,c,i,j; 10 memset(a,0,sizeof(a)); 11 a[1][0]=a[2][0]=1; 12 for(i=3;i<10001;i++) 13 { 14 c=0; 15 for(j=0;j<=999;j++) 16 { 17 a[i][j]=(a[i-2][j]+a[i-1][j]+c)%len; 18 c=(a[i-2][j]+a[i-1][j]+c)/len; 19 } 20 } 21 while(cin>>n) 22 { 23 for(i=999;i>=0;i--) 24 if(a[n][i]!=0) 25 break; 26 cout<<a[n][i]; 27 for(i--;i>=0;i--) 28 { 29 printf("%08d",a[n][i]); 30 } 31 cout<<endl; 32 } 33 }
标签:
原文地址:http://www.cnblogs.com/a1225234/p/4675601.html