Submission #984527

#TimeUsernameProblemLanguageResultExecution timeMemory
984527Ahmed57Alternating Current (BOI18_alternating)C++17
0 / 100
19 ms10212 KiB
#include <bits/stdc++.h> using namespace std; #define int long long signed main(){ ios_base::sync_with_stdio(false);cin.tie(0); int n,m;cin>>n>>m; int pref[n+2] = {0}; vector<array<int,3>> v; vector<array<int,2>> rng[n+1]; int dir[n+1] = {0}; for(int i = 0;i<m;i++){ int a,b;cin>>a>>b; if(a<=b){ pref[a]++; pref[b+1]--; }else{ pref[a]++; pref[1]++; pref[b+1]--; b+=n; } v.push_back({a,b,i}); rng[a].push_back({b,i}); } for(int i = 2;i<=n;i++){ pref[i]+=pref[i-1]; } for(int i = 0;i<m;i++){ for(int j = 0;j<m;j++)dir[j] = 0; int ind = v[i][0]; int nah = v[i][1], fe = v[i][2]; bool bad = 0; while(ind<v[i][0]+n){ if(nah==-1){ bad = 1; break; } int er = nah; dir[fe] = 1; if(er>=v[i][0]+n){ break; } while(ind<=er){ ind++; for(auto j:rng[(ind-1)%n+1]){ if(nah<(j[0]>n?j[0]:(ind<=n?j[0]:j[0]+n))){ nah = (j[0]>n?j[0]:(ind<=n?j[0]:j[0]+n)); fe = j[1]; } } if(pref[(ind-1)%n+1]==2)nah = -1; } } if(bad==0){ for(int j = 0;j<m;j++){ cout<<dir[j]; } return 0; } } cout<<"impossible\n"; }
#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...