QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#225330 | #4937. Permutation Transformation | Rabeya# | WA | 6ms | 4752kb | C++20 | 2.3kb | 2023-10-24 15:07:15 | 2023-10-24 15:07:16 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
typedef long long int ll;
typedef pair<int,int> pii;
typedef vector<int> vii;
typedef vector<ll> vll;
typedef vector<pii> vpii;
typedef unordered_map<int,int> umap;
typedef long double ld;
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define popcount __builtin_popcount
#define case cout<<"Case "<<__testcase-testcase<<": ";
//#define endl '\n'
const ll mod=998244353;
long long binpow(long long a, long long b) {
long long res = 1;
while (b > 0) {
if (b & 1)
res = (res * a)%mod;
a = (a * a)%mod;
b >>= 1;
}
return res;
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
int testcase=1;
//cout<<inv(2)<<endl;
//cin>>testcase;
int __testcase=testcase;
while(testcase--){
int n;
cin>>n;
int p[n+1];
for(int i=1;i<=n;i++) {
cin>>p[i];
}
vector<int> v;
int vis[n+1]={0};
for(int i=1;i<=n;i++){
if(!vis[p[i]]){
int len=0;
int now=p[i];
while(!vis[now]){
len++;
vis[now]=1;
now=p[now];
}
v.pb(len);
}
}
int cnt[n+1]={0};
int ok=0;
for(int i=0;i<v.size();i++){
int now=v[i]-1;
if(now==1){
ok=1;
continue;
}
if(now==0) continue;
for(int j=2;j*j<=now;j++){
if(now%j==0){
int num=0;
while(now%j==0){
now/=j;
num++;
}
cnt[j]=max(cnt[j],num);
// cout<<j<<" "<<num<<endl;
}
}
if(now!=1) cnt[now]=max(cnt[now],1);
}
ll ans=1;
//cout<<ok<<endl;
for(int i=1;i<=n;i++) ans=(ans*binpow(i,cnt[i]))%mod;
if(ok) cout<<(ans+1)%mod<<endl;
else cout<<ans<<endl;
}
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3528kb
input:
5 3 5 1 2 4
output:
3
result:
ok single line: '3'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3580kb
input:
8 7 5 1 6 8 2 3 4
output:
4
result:
ok single line: '4'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3636kb
input:
1 1
output:
1
result:
ok single line: '1'
Test #4:
score: -100
Wrong Answer
time: 6ms
memory: 4752kb
input:
100000 20864 34918 58550 1465 75674 30743 27235 88900 47488 50029 46054 84871 20330 72228 16506 44561 92519 97750 82891 60324 90508 39290 24663 38077 90189 30671 95476 64027 70888 90749 22566 8525 33675 16635 23392 97636 35788 89625 41966 78051 94034 15407 26545 83799 2233 10873 56946 71566 19045 44...
output:
338374676
result:
wrong answer 1st lines differ - expected: '216333199', found: '338374676'