mirror of
https://github.com/Kiritow/OJ-Problems-Source.git
synced 2024-03-22 13:11:29 +08:00
46f6aa3fc4
2200-2299
79 lines
1.6 KiB
C++
79 lines
1.6 KiB
C++
#include <iostream>
|
|
using namespace std;
|
|
int B[4][4]={
|
|
{1,1,0,1},
|
|
{1,1,1,0},
|
|
{0,1,1,1},
|
|
{1,0,1,1}
|
|
};
|
|
struct In{
|
|
int A[4][4];
|
|
};
|
|
In a,b;
|
|
void f(int n)
|
|
{
|
|
int i,j;
|
|
if(n==0)
|
|
{
|
|
for(i=0; i<4; i++)
|
|
{
|
|
for(j=0; j<4; j++)
|
|
{
|
|
b.A[i][j]=B[i][j];
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
f(n-1);
|
|
for(i=0; i<4; i++)
|
|
{
|
|
for(j=0; j<4; j++)
|
|
{
|
|
a.A[i][j]=b.A[i][j];
|
|
a.A[i][j]%=9937;
|
|
}
|
|
}
|
|
if(n==1)
|
|
return ;
|
|
for(i=0; i<4; i++)
|
|
{
|
|
b.A[i][0]=a.A[i][0]+a.A[i][1]+a.A[i][3];
|
|
b.A[i][1]=a.A[i][0]+a.A[i][2]+a.A[i][1];
|
|
b.A[i][2]=a.A[i][1]+a.A[i][2]+a.A[i][3];
|
|
b.A[i][3]=a.A[i][0]+a.A[i][2]+a.A[i][3];
|
|
}
|
|
}
|
|
}
|
|
void Solve()
|
|
{
|
|
int i,j,e,f,sum=0;
|
|
for(i=0; i<4; i++)
|
|
{
|
|
for(j=0; j<4; j++)
|
|
{
|
|
for(e=0; e<4; e++)
|
|
{
|
|
for(f=0; f<4; f++)
|
|
{
|
|
if(i==j || i==e || i==f || j==e || j==f || e==f)
|
|
continue;
|
|
sum+=((((((b.A[0][i]*b.A[1][j])%9937)*b.A[2][e])%9937)*b.A[3][f])%9937)%9937;
|
|
sum%=9937;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
cout<<sum<<endl;
|
|
}
|
|
int main()
|
|
{
|
|
int n;
|
|
while(cin>>n)
|
|
{
|
|
f(n);
|
|
Solve();
|
|
}
|
|
return 0;
|
|
}
|