Submission #940269

#TimeUsernameProblemLanguageResultExecution timeMemory
940269GrandTiger1729Passport (JOI23_passport)C++17
48 / 100
2090 ms63268 KiB
#include <bits/stdc++.h> using namespace std; const int N = 2e5 + 10, INF = 1e9 + 10; struct SegTree { int l, r, mid; SegTree *lc, *rc; int val = INF; SegTree(int l_, int r_) : l(l_), r(r_) { mid = (l + r) / 2; if (l == r - 1) { return; } lc = new SegTree(l, mid); rc = new SegTree(mid, r); } ~SegTree() { if (l == r - 1) { return; } delete lc; delete rc; } void update(int i, int u) { if (l == r - 1) { val = u; return; } if (i < mid) { lc->update(i, u); } else { rc->update(i, u); } val = min(lc->val, rc->val); } int query(int ll, int rr) { if (ll <= l && rr >= r) { return val; } int ret = INF; if (ll < mid) { ret = min(ret, lc->query(ll, rr)); } if (mid < rr) { ret = min(ret, rc->query(ll, rr)); } return ret; } }; int main() { cin.tie(0)->sync_with_stdio(0); int n; cin >> n; vector<pair<int, int>> a(n); for (int i = 0; i < n; i++) { int l, r; cin >> l >> r; l--; a[i] = make_pair(l, r); } vector<int> dpl(n, INF), dpr(n, INF); SegTree stl(0, n); stl.update(0, 0); dpl[0] = 0; for (int i = 1; i < n; i++) { dpl[i] = min(dpl[i], a[i].first > 0 ? 1 + stl.query(a[i].first, i) : 0); stl.update(i, dpl[i]); } SegTree str(0, n); str.update(n - 1, 0); dpr[n - 1] = 0; for (int i = n - 2; i >= 0; i--) { dpr[i] = a[i].second < n ? 1 + str.query(i, a[i].second) : 0; str.update(i, dpr[i]); } vector<pair<int, int>> res(n); for (int i = 0; i < n; i++) { res[i] = make_pair(min(INF, min(dpl[i], 1 + stl.query(a[i].first, a[i].second)) + min(dpr[i], 1 + str.query(a[i].first, a[i].second))), i); } sort(res.begin(), res.end()); vector<int> ans(n, INF); SegTree st(0, n); for (int tt = 0; tt < n; tt++) { for (auto [d, i] : res) { ans[i] = min(ans[i], min(d, 1 + st.query(a[i].first, a[i].second))); st.update(i, ans[i]); } } int q; cin >> q; while (q--) { int i; cin >> i; i--; cout << (ans[i] == INF ? -1 : ans[i] + 1) << '\n'; } 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...