#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
struct matrix
{
int a[2][2];
}origin,p;
matrix Sum(matrix x,matrix y)
{
matrix temp;
memset(temp.a,0,sizeof(temp.a));
int i,j,k;
for(i=0;i<2;i++)
{
for(j=0;j<2;j++)
{
for(k=0;k<2;k++)
{
temp.a[i][j]=(temp.a[i][j]+x.a[i][k]*y.a[k][j])%10000;
}
}
}
return temp;
}
int main()
{
int n,i,j;
//matrix final,temp;
while(~scanf("%d",&n)&&n!=-1)
{
origin.a[0][0]=1;
origin.a[0][1]=0;
origin.a[1][0]=1;
origin.a[1][1]=0;
p.a[0][0]=1;
p.a[0][1]=1;
p.a[1][0]=1;
p.a[1][1]=0;
if(n==0)
{
printf("0\n");
continue;
}
while(n!=0)
{
if(n&1)
origin=Sum(origin,p);
p=Sum(p,p);
n>>=1;
}
printf("%d\n",origin.a[0][1]);
}
return 0;
}
POJ3070
最新推荐文章于 2023-01-07 14:41:09 发布