【2021 Multi-University 2 J】I love permutation 题解
题目大意
给定一个 $a$ 和一个奇质数 $p$($1 \le a<p$),令 $b_x=ax\bmod p,\ x=1,2,\cdots,p-1$,则 $b$ 序列形成一个 $1$ 到 $p-1$ 的排列,求这个排列的逆序对数量 $\bmod 2$。
$p \le 10^{18}$
多测,$T \le 10^5$
1s
题解
排列 $b_1,\cdots,b_n$ 的逆序对数量的奇偶性用这个式子表示,奇数就得到 $-1$,偶数就得到 $1$:
这是因为,分子的 $(b_j,b_i)$ 如果是正序对,那么会跟分母的 $b_i-b_j$ 约掉;如果是逆序对,那么跟分母约掉之后还会多出一个 $-1$。
式子代入这题:
所以就只需判断 $a^{\frac{p-1}{2}}$ 是 $1$ 还是 $-1$。
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
| #include<bits/stdc++.h> #define fo(i,a,b) for(int i=a;i<=b;i++) using namespace std;
typedef long long LL;
LL mul(LL a,LL b,LL n) {return(a*b-(LL)(a/(long double)n*b+1e-3)*n+n)%n;}
LL Pow(LL x,LL y,LL mo) { LL re=1; for(; y; y>>=1, x=mul(x,x,mo)) if (y&1) re=mul(re,x,mo); return re; }
int main() { int T; scanf("%d",&T); while (T--) { LL a,p; scanf("%lld %lld",&a,&p); printf("%d\n",(Pow(a,(p-1)>>1,p)&1)^1); } }
|