本文共 2039 字,大约阅读时间需要 6 分钟。
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 11104 Accepted Submission(s): 3732
1 #include2 using namespace std; 3 int a[10000][260]={ 0}; //每个元素可以存储8位数字,所以2005位可以用260个数组元素存储。 4 int main() 5 { 6 int i,j,n; 7 a[1][0]=1; //赋初值 8 a[2][0]=1; 9 a[3][0]=1;10 a[4][0]=1;11 for(i=5;i<10000;i++)12 {13 for(j=0;j<260;j++)14 a[i][j]+=a[i-1][j]+a[i-2][j]+a[i-3][j]+a[i-4][j];15 for(j=0;j<260;j++) //每八位考虑进位。16 if(a[i][j]>100000000)17 {18 a[i][j+1]+=a[i][j]/100000000;19 a[i][j]=a[i][j]%100000000;20 }21 }22 while(scanf("%d",&n)!=EOF)23 {24 for(j=259;j>=0;j--)25 if(a[n][j]!=0) break; //不输出高位的026 printf("%d",a[n][j]);27 for(j=j-1;j>=0;j--)28 printf("%08d",a[n][j]); //每个元素存储了八位数字,所以控制输出位数为8,左边补029 printf("\n");30 }31 return 0;32 }
您可以考虑给博主来个小小的打赏以资鼓励,您的肯定将是我最大的动力。thx.
微信打赏
支付宝打赏
作 者: 出 处: 关于作者:潜心机器学习以及信息安全的综合研究。如有问题或建议,请多多赐教! 版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。 特此声明:所有评论和私信都会在第一时间回复。也欢迎园子的大大们指正错误,共同进步。或者我 声援博主:如果您觉得文章对您有帮助,可以点击右下角【】推荐一下该博文。您的鼓励是作者坚持原创和持续写作的最大动力!