Submission #658966

#TimeUsernameProblemLanguageResultExecution timeMemory
658966600MihneaNew Home (APIO18_new_home)C++17
10 / 100
354 ms47672 KiB
bool home = 0; #include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = (int) 3e5 + 7; const int INF = (int) 1e9 + 7; int n; int k; int q; struct T { int x; int t; int a; int b; }; T v[N]; vector<int> gs[N]; struct Q { int x; int t; }; bool operator < (Q a, Q b) { return a.t < b.t; } struct U { int pos; int x; }; int main() { if (home == 0) { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); } else { freopen ("input.txt", "r", stdin); } cin >> n >> k >> q; for (int i = 1; i <= n; i++) { cin >> v[i].x >> v[i].t >> v[i].a >> v[i].b; v[i].x *= 2; gs[v[i].t].push_back(i); } vector<pair<int, int>> qs(q); vector<int> inv(q); for (int iq = 0; iq < q; iq++) { int t; cin >> qs[iq].first >> t; qs[iq].first *= 2; qs[iq].second = iq; } sort(qs.begin(), qs.end()); for (int i = 0; i < q; i++) { inv[qs[i].second] = i; } vector<int> sol(q, 0); vector<U> lft, rgh; for (int tp = 1; tp <= k; tp++) { if (gs[tp].empty()) { continue; } sort(gs[tp].begin(), gs[tp].end(), [&] (int i, int j) { return v[i].x < v[j].x; }); for (int i = 0; i + 1 < (int) gs[tp].size(); i++) { T cur = v[gs[tp][i]]; T nxt = v[gs[tp][i + 1]]; lft.push_back({(cur.x + nxt.x) / 2, cur.x}); rgh.push_back({(cur.x + nxt.x) / 2, nxt.x}); } rgh.push_back({-(int) 2e8, v[gs[tp][0]].x}); lft.push_back({+(int) 2e8, v[gs[tp].back()].x}); } sort(rgh.begin(), rgh.end(), [&] (U a, U b) { return a.pos < b.pos; }); { int mx = -((int) 1e9 + 7); int pt = 0; for (int i = 0; i < q; i++) { int x = qs[i].first; while (pt < (int) rgh.size() && rgh[pt].pos <= x) { mx = max(mx, rgh[pt++].x); } sol[i] = max(sol[i], mx - x); } } sort(lft.begin(), lft.end(), [&] (U a, U b) { return a.pos > b.pos; }); { int mn = ((int) 1e9 + 7); int pt = 0; for (int i = q - 1; i >= 0; i--) { int x = qs[i].first; while (pt < (int) lft.size() && x <= lft[pt].pos) { mn = min(mn, lft[pt++].x); } sol[i] = max(sol[i], x - mn); } } for (int i = 0; i < q; i++) { cout << sol[inv[i]] / 2 << "\n"; } return 0; for (int iq = 1; iq <= q; iq++) { int x, t; cin >> x >> t; qs.push_back({x, iq}); int sol = -INF; for (int tp = 1; tp <= k; tp++) { int nr = INF; for (auto &i : gs[tp]) { if (v[i].a <= t && t <= v[i].b) { nr = min(nr, abs(x - v[i].x)); } } sol = max(sol, nr); } if (sol == INF) { sol = -1; } cout << sol << "\n"; } return 0; }

Compilation message (stderr)

new_home.cpp: In function 'int main()':
new_home.cpp:42:13: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   42 |     freopen ("input.txt", "r", stdin);
      |     ~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#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...