Submission #537384

#TimeUsernameProblemLanguageResultExecution timeMemory
537384ac2huRMQ (NOI17_rmq)C++14
67 / 100
1065 ms10124 KiB
#include <bits/stdc++.h> #ifdef DEBUG #include "../templates/debug.h" #else #define deb(x...) #endif using namespace std; const int N = 1e5 + 10; int n,m; int ans[N], uq[N]; pair<int,int> seq[N]; pair<int,int> fseq[N]; signed main() { iostream::sync_with_stdio(false); cin.tie(nullptr);cout.tie(nullptr); cin >> n >> m; for(int i =0 ;i<n;i++){ ans[i] = -1; seq[i] = {-1,-1}; fseq[i] = {-1,-1}; } auto merge = [&](pair<int,int> a,pair<int,int> b) -> pair<int,int>{ return {min(a.first,b.first), max(a.second,b.second)}; // LARGEST RANGE WHERE IT IS MINIMUM }; for(int _ = 0;_<m;_++){ int l,r,a;cin >> l >> r >> a; if(seq[a].first == -1){ seq[a] = {l,r}; fseq[a] = {l,r}; } else{ fseq[a] = {max(fseq[a].first,l), min(fseq[a].second,r)}; seq[a] = merge(seq[a], {l,r}); } } for(int i = 0;i<n;i++){ if(seq[i].second < seq[i].first){ for(int i= 0;i<n;i++){ cout << -1 << " "; } exit(0); } } // deb(i,seq[i]); set<int> s; for(int i = 0;i<n;i++) s.insert(i); vector<int> not_selected; for(int i = n - 1;i>=0;i--){ if(seq[i].first == -1) not_selected.push_back(i); else{ auto temp = s.lower_bound(fseq[i].first); if(temp == s.end() || *temp > fseq[i].second){ for(int i= 0;i<n;i++){ cout << -1 << " "; } exit(0); } else{ uq[*temp] = i; ans[*temp] = i; s.erase(temp); } set<int> temp1 = s; auto it = s.lower_bound(seq[i].first); // --it; auto end = s.upper_bound(seq[i].second); for(auto tt = it;tt != end;++tt){ uq[*tt] = max(i, uq[*tt]); temp1.erase(temp1.find(*tt)); } swap(temp1,s); } } // for(int i =0;i<n;i++) // cout << ans[i] << " "; // cout << "\n"; vector<int> temp; for(int i =0;i<n;i++){ if(ans[i] == -1) temp.push_back(i); } sort(temp.begin(),temp.end(),[&](int a,int b){ return uq[a] < uq[b]; }); deb(temp); // cout << temp.back() << "\n"; for(int i = n - 1;i>=0;i--){ if(seq[i].first == -1){ if(uq[temp.back()] > i){ for(int i= 0;i<n;i++) cout << -1 << " "; exit(0); } ans[temp.back()] = i; temp.pop_back(); } } for(int i =0 ;i<n;i++) cout << ans[i] << " "; cout << "\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...