第
那麼就可以列出方程:
最後一個沒有用了,只用
然後用
【代碼】
#include <cstdio>
#include <iostream>
#include <algorithm>
#define N 25
#define INF 0x7fffffff
using namespace std;
typedef long long ll;
ll read()
{
ll x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
int n,M,R;
int a[N],pos[N],m[N],r[N];
void Exgcd(int a,int b,int &d,int &x,int &y)
{
if(b) {
Exgcd(b,a%b,d,y,x);
y-=(a/b)*x;
}
else x=1,y=0,d=a;
}
int Ex_CRT()
{
M=m[1],R=r[1];int x,y,d;
for(int i=2;i<n;i++)
{
Exgcd(M,m[i],d,x,y);
if((r[i]-R)%d) return -1;
R=(r[i]-R)/d*x%(m[i]/d)*M+R;
M*=m[i]/d;
R%=M;
}
R=(R+M)%M;if(!R) R=M;
return R;
}
int main()
{
n=read();
for(int i=1;i<=n;i++) {
a[i]=read();
pos[a[i]]=i;
}
for(int i=1;i<n;i++)
{
int x=pos[i];
int j=pos[i-1];
while(j!=x) {
j++;if(j>n) j=1;
if(a[j]>=i) r[i]++;
}
m[i]=n-i+1;r[i]%=m[i];
}
int Ans=Ex_CRT();
if(Ans==-1) printf("NIE\n");
else printf("%d\n",Ans);
return 0;
}