风雪孤影 @ 2020-11-26 23:53:26
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
int max=10000;
int n,m,jw;
int a[max],b[max],c[max];
cin>>n;
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
memset(c,0,sizeof(c));
m=1;
jw=0;
a[m]=1;
b[m]=2;
for(int i=3;i<=n;i++)
{for(int j=1;j<=m;j++)
{c[j]=a[j]+b[j]+jw;
if(c[j]>=10)
{jw=1;
if(j==m)
m++;
c[j]-=10;}
else
jw=0;}
for(int f=1;f<=m;f++)
{a[f]=b[f];
b[f]=c[f];}
}
for(int p=m;p>=1;p--)
cout<<c[p];
return 0;
}
by _OJF_ @ 2020-11-27 00:22:51
@风雪孤影 高精
by 小仓朝阳 @ 2020-11-27 07:38:27
能缩进一下吗qaq
by 风雪孤影 @ 2020-11-27 12:32:06
@chengzhiyu蒻蒟 不是已经用数组存然后竖式计算了吗qaq
by 风雪孤影 @ 2020-11-27 12:32:45
@小仓朝阳 什么是缩进啊,蒟蒻什么都不会
by 风雪孤影 @ 2020-11-27 12:43:29
我过了,原来少了n<=3的,谢谢大佬们