#include <bits/stdc++.h> using namespace std; #define MAXN 10000000 bool f[MAXN+10]; int phi[MAXN+10],pri[MAXN+10],n,cnt; void Get_phi(){//欧拉筛筛出范围内的所有phi值 phi[1]=1; for(int i=2;i<=MAXN;i++) { if(!f[i]){ pri[++cnt]=i;//保存质数 phi[i]=i-1; } for(int j=1;j<=cnt&&i*pri[j]<=MAXN;j++){ f[i*pri[j]]=1;//标记已筛量 if(i%pri[j]==0){ phi[i*pri[j]]=phi[i]*pri[j]; break; } else phi[i*pri[j]]=phi[i]*(pri[j]-1); } } } int qpow(int a,int b,int mod)//快速幂筛选降低mod { int ans=1; for(;b;b>>=1){ if(b&1) ans=(long long)a*ans%mod; a=(long long)a*a%mod; } return ans; } int solve(int mod)//递归降幂 { if(mod==1) return 0; else return qpow(2,solve(phi[mod])+phi[mod],mod); } int main() { #ifndef ONLINE_JUDGE freopen("4139.txt","r",stdin); freopen("out.txt","w",stdout); #endif Get_phi(); scanf("%d",&n); for(int i=1;i<=n;i++) { int p; scanf("%d",&p); printf("%d\n",solve(p)); } return 0; }
洛谷P4139上帝与集合的正确用法代码实现,今日份学习