Submission #1135995

#TimeUsernameProblemLanguageResultExecution timeMemory
1135995Ak_16Gondola (IOI14_gondola)C++20
75 / 100
13 ms2888 KiB
#include <iostream> #include <algorithm> #include "gondola.h" using namespace std; int p = 1e9+9; int b[300005]; int cnt[300005]; int cha[300005]; int brbr[300005]; int val; int fin; int ok; long long ans; bool cmp(int x, int y){ return b[x]<b[y]; } int valid(int n, int a[]){ int cn=0; int bruh=0; int sp=0; for(int i=0; i<n; i++){ cnt[a[i]]++; if(cnt[a[i]]>1){bruh=1;} if(a[i]<=n){cn++; sp = i;} } if(bruh==1){return 0;} if(cn>0){ for(int i=0; i<n; i++){ b[(2*n+a[sp]-sp+i-1)%n] = a[i]; } } else { for(int i=0; i<n; i++){b[i] = a[i];} } if(cn==0){return 1;} else { int bru=0; for(int i=0; i<n; i++){ if(b[i]<=n&&b[i]!=i+1){bru=1;} } return (1-bru); } } int replacement(int n, int a[], int c[]){ int k = valid(n, a); if(k==0){return 0;} else { int don=0; val=0; ans=1; for(int i=0; i<n; i++){ if(b[i]!=i+1){val++; cha[val] = i; } } fin=val; sort(cha+1, cha+val+1, cmp); ok = n; for(int i=1; i<=val; i++){ don++; c[don-1] = cha[i]+1; for(int j =1; j<= b[cha[i]]-ok-1; j++){ don++; c[don-1] = ok+j; ans *= (val-i+1); ans %= p; } ok = b[cha[i]]; } return don; } } int countReplacement(int n, int a[]){ int n1 = valid(n, a); if(n1==0){ return 0;} else { val=0; ans=1; for(int i=0; i<n; i++){ if(b[i]!=i+1){val++; cha[val] = i; } } fin=val; sort(cha+1, cha+val+1, cmp); ok = n; for(int i=1; i<=val; i++){ for(int j =1; j<= b[cha[i]]-ok-1; j++){ ans *= (val-i+1); ans %= p; } ok = b[cha[i]]; } return ans; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...