QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#828022 | #4492. Yet Another Easy Permutation Count Problem | Sai_tqwq | AC ✓ | 2954ms | 74148kb | C++14 | 2.5kb | 2024-12-23 12:26:29 | 2024-12-23 12:26:31 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int mod=998244353;
int cas,n,m,k,a[1000009],b[1000009],fct[1000009],ifct[1000009];
bool vis[1000009];
void ad(int &x,int y){x+=y;if(x>=mod)x-=mod;}
struct fenwick{
int c[1000009];
void upd(int x,int f){while(x<=n)ad(c[x],f),x+=x&-x;}
int query(int x){int f=0;while(x)ad(f,c[x]),x-=x&-x;return f;}
int query(int l,int r){return (query(r)+mod-query(l-1))%mod;}
}tr1,tr2,tr3;
int qpow(int a,int b,int res=1){
while(b){if(b&1)res=res*a%mod;a=a*a%mod;b>>=1;}
return res;
}
int C(int x,int y){
if(x<0||y<0||x<y)return 0;
return fct[x]*ifct[y]%mod*ifct[x-y]%mod;
}
signed main(){
ios::sync_with_stdio(0);
cin.tie(0);cout.tie(0);
fct[0]=1;for(int i=1;i<=1000000;i++)fct[i]=fct[i-1]*i%mod;
ifct[1000000]=qpow(fct[1000000],mod-2);for(int i=999999;~i;i--)ifct[i]=ifct[i+1]*(i+1)%mod;
cin>>cas;
while(cas--){
cin>>n>>m;
for(int i=1;i<=n;i++)a[i]=b[i]=tr1.c[i]=tr2.c[i]=tr3.c[i]=vis[i]=0;
vector<int> vec;
for(int i=1;i<=m;i++){
int p,x;cin>>p>>x;
b[p]=x;
vis[x]=1;
}
for(int i=1;i<=n;i++)if(!vis[i])vec.push_back(i);
k=(int)vec.size();
for(int i=1;i<=n;i++)if(b[i])a[i]=lower_bound(vec.begin(),vec.end(),b[i])-vec.begin()+1;
int ans=0;
for(int i=1,cnt=0,totp=0;i<n;i++){
if(!a[i]&&!a[i+1]){
ad(ans,totp*fct[k-2]%mod);
if(cnt)ad(ans,cnt*C(k,3)%mod*fct[k-3]%mod);
ad(ans,C(k,2)*fct[k-2]%mod);
}else if(!a[i]&&a[i+1]){
ad(ans,tr2.query(b[i+1],n)*fct[k-1]%mod);
if(cnt)ad(ans,cnt*C(k+1-a[i+1],2)%mod*fct[k-2]%mod);
ad(ans,(k+1-a[i+1])*fct[k-1]%mod);
}else if(a[i]&&!a[i+1]){
ad(ans,tr1.query(b[i])*fct[k-1]%mod);
if(cnt)ad(ans,cnt*C(a[i]-1,2)%mod*fct[k-2]%mod);
ad(ans,(a[i]-1)*fct[k-1]%mod);
}else if(b[i]>b[i+1]){
ad(ans,tr3.query(b[i+1],b[i])*fct[k]%mod);
if(cnt)ad(ans,cnt*(a[i]-a[i+1])%mod*fct[k-1]%mod);
ad(ans,fct[k]);
}
if(!b[i])cnt++;
else {
ad(totp,(a[i]-1)*(k+1-a[i])%mod);
tr1.upd(b[i],a[i]-1);
tr2.upd(b[i],k+1-a[i]);
tr3.upd(b[i],1);
}
}
cout<<ans<<endl;
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 2954ms
memory: 74148kb
input:
100 1 1 1 1 7513 7311 5538 3089 3928 1029 5512 3849 100 1643 7328 4748 5811 196 6557 2258 3348 790 2760 882 1297 689 7500 6955 3619 3686 3724 3401 6412 4691 6471 4947 6315 5754 1752 1086 2648 124 6721 2929 7185 5179 7239 6148 3005 7383 6676 3884 3074 6165 5062 5842 1145 5090 7376 848 5418 6441 275 6...
output:
0 89541616 367554988 216909100 990456909 526769607 506026027 780187494 553834792 144362048 842584375 861132490 730089994 250057476 295193259 96890952 451932499 132980145 430587965 19967698 589057985 811887276 759432199 345092973 588708812 875024174 665937616 34601572 507128381 479135581 798327226 74...
result:
ok 100 lines