Submission #668084

#TimeUsernameProblemLanguageResultExecution timeMemory
668084600MihneaTram (CEOI13_tram)C++17
25 / 100
1088 ms804 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 150000 + 7; const ll INF = (ll) 1e18 + 7; int n; int cnt_active; bool is_active[N][2]; int rsol[N]; int csol[N]; set<int> randuriInteresantePeColoana[2]; set<int> randuriInteresante; set<pair<int, int>> perechiDeRanduriInteresanteConsecutive; void add_row(int r) { assert(1 <= r && r <= n); if (randuriInteresante.count(r)) { return; } randuriInteresante.insert(r); assert((int) randuriInteresante.size() >= 2); /// optimize here: perechiDeRanduriInteresanteConsecutive.clear(); int last = -1; for (auto &r : randuriInteresante) { if (last != -1) { perechiDeRanduriInteresanteConsecutive.insert({last, r}); } last = r; } } void del_row(int r) { assert(1 <= r && r <= n); if (r == 1 || r == n) { return; } assert(randuriInteresante.count(r)); randuriInteresante.erase(r); assert((int) randuriInteresante.size() >= 2); /// optimize here: perechiDeRanduriInteresanteConsecutive.clear(); int last = -1; for (auto &r : randuriInteresante) { if (last != -1) { perechiDeRanduriInteresanteConsecutive.insert({last, r}); } last = r; } } void add(int r, int c) { assert(1 <= r && r <= n); assert(0 <= c && c <= 1); assert(is_active[r][c] == 0); assert(!randuriInteresantePeColoana[c].count(r)); is_active[r][c] = 1; cnt_active++; randuriInteresantePeColoana[c].insert(r); add_row(r); } void del(int r, int c) { assert(1 <= r && r <= n); assert(0 <= c && c <= 1); assert(cnt_active >= 1); assert(is_active[r][c] == 1); assert(randuriInteresante.count(r)); assert(randuriInteresantePeColoana[c].count(r)); is_active[r][c] = 0; cnt_active--; randuriInteresantePeColoana[c].erase(r); if (!randuriInteresantePeColoana[c ^ 1].count(r)) { del_row(r); } } ll computeDist(int r, int c) { assert(1 <= r && r <= n); assert(0 <= c && c <= 1); assert(cnt_active >= 1); ll sol = INF; for (int inv = 0; inv <= 1; inv++) { auto it = randuriInteresantePeColoana[c ^ inv].lower_bound(r); if (it != randuriInteresantePeColoana[c ^ inv].end()) { sol = min(sol, 1LL * (*it - r) * (*it - r) + inv); } if (it != randuriInteresantePeColoana[c ^ inv].begin()) { it--; sol = min(sol, 1LL * (*it - r) * (*it - r) + inv); } } return sol; } void bagaCePoti(int iq) { if (cnt_active == 0) { rsol[iq] = 1; csol[iq] = 0; return; } assert(cnt_active >= 1); ll bg = 0; set<pair<int, int>> guys; for (auto &it : perechiDeRanduriInteresanteConsecutive) { guys.insert({it.first, 0}); guys.insert({it.first, 1}); guys.insert({it.second, 0}); guys.insert({it.second, 1}); guys.insert({(it.first + it.second) / 2, 0}); guys.insert({(it.first + it.second) / 2, 1}); guys.insert({(it.first + it.second + 1) / 2, 0}); guys.insert({(it.first + it.second + 1) / 2, 1}); for (auto &p : guys) { bg = max(bg, computeDist(p.first, p.second)); } } for (auto &p : guys) { if (bg == computeDist(p.first, p.second)) { rsol[iq] = p.first; csol[iq] = p.second; return; } } assert(0); } int main() { #ifdef ONPC freopen ("input.txt", "r", stdin); #endif // ONPC #ifndef ONPC ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); #endif // ONPC int q; cin >> n >> q; if (n == 1) { cout << "fuck this special case\n"; exit(0); } randuriInteresante.insert(1); randuriInteresante.insert(n); perechiDeRanduriInteresanteConsecutive.insert({1, n}); for (int iq = 1; iq <= q; iq++) { string s; cin >> s; assert(s == "E" || s == "L"); if (s == "E") { bagaCePoti(iq); cout << rsol[iq] << " " << csol[iq] + 1 << "\n"; add(rsol[iq], csol[iq]); continue; } assert(s == "L"); int pos; cin >> pos; del(rsol[pos], csol[pos]); } return 0; }
#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...