Submission #1010488

#TimeUsernameProblemLanguageResultExecution timeMemory
1010488MardonbekhazratovGondola (IOI14_gondola)C++17
60 / 100
27 ms6344 KiB
#include "gondola.h" #include<bits/stdc++.h> using namespace std; int valid(int n, int inputSeq[]){ int mn=n,id=-1; map<int,int>cnt; for(int i=0;i<n;i++){ cnt[inputSeq[i]]++; if(inputSeq[i]<=mn){ mn=inputSeq[i]; id=i; } } for(auto [x,y]:cnt){ if(y>1) return 0; } if(mn==n) return 1; id=(id-mn+1+n)%n; for(int i=0;i<n;i++){ if(inputSeq[(id+i)%n]==i+1 || inputSeq[(id+i)%n]>n) continue; return 0; } return 1; } //---------------------- int replacement(int n, int gondolaSeq[], int replacementSeq[]){ const int N=2.5e5; vector<int>cnt(N+1,0); int mn=N,id=0,mx=0; set<int>s; set<pair<int,int>>t; for(int i=0;i<n;i++){ cnt[gondolaSeq[i]]++; if(gondolaSeq[i]<mn){ mn=gondolaSeq[i]; id=i; } mx=max(mx,gondolaSeq[i]); if(gondolaSeq[i]<=n) s.insert(gondolaSeq[i]); else t.insert({gondolaSeq[i],i}); } if(mn<=n){ id=(id-mn+1+n)%n; } int ans=0,last=n+1; for(auto [x,y]:t){ int k=(y-id+n)%n; replacementSeq[ans++]=k+1; for(int j=last;j<x;j++) replacementSeq[ans++]=j; last=x+1; } return ans; } //---------------------- int countReplacement(int n, int inputSeq[]){ const int MOD=1e9+9; if(!valid(n,inputSeq)){ return 0; } int c=0; for(int i=0;i<n;i++){ if(inputSeq[i]>n) c++; } int replacementSeq[(int)3e5]; int l=replacement(n,inputSeq,replacementSeq); int ans=1; for(int i=0;i<l-c;i++){ ans=1LL*ans*c%MOD; } 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...