QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#828022#4492. Yet Another Easy Permutation Count ProblemSai_tqwqAC ✓2954ms74148kbC++142.5kb2024-12-23 12:26:292024-12-23 12:26:31

Judging History

你现在查看的是最新测评结果

  • [2024-12-23 12:26:31]
  • 评测
  • 测评结果:AC
  • 用时:2954ms
  • 内存:74148kb
  • [2024-12-23 12:26:29]
  • 提交

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