Submission #1233724

#TimeUsernameProblemLanguageResultExecution timeMemory
1233724lopkus운세 보기 2 (JOI14_fortune_telling2)C++20
100 / 100
369 ms39780 KiB
#include <bits/stdc++.h> #define int int64_t const int N = 1e6 + 5; struct segtree{ int t[4 * N] = {0}; int query(int v, int tl, int tr, int l, int r) { if(tl > r || tr < l) { return 0; } if(tl >= l && tr <= r) { return t[v]; } int tm = (tl + tr) / 2; return std::max(query(v * 2, tl, tm, l, r), query(v * 2 + 1, tm + 1, tr, l, r)); } void update(int v, int tl, int tr, int index, int value) { if(tl == tr) { t[v] = value; } else { int tm = (tl + tr) / 2; if(index <= tm) { update(v * 2, tl, tm, index, value); } else { update(v * 2 + 1, tm + 1, tr, index, value); } t[v] = std::max(t[v * 2], t[v * 2 + 1]); } } }seg; struct fenw { int t[2 * N]; void update(int i, int v) { for(; i < N; i += i & - i) { t[i] += v; } } int query(int i) { int ans = 0; for(; i > 0; i -= i & - i) { ans += t[i]; } return ans; } int query(int l, int r) { return query(r) - query(l - 1); } }fenw; signed main() { int n, q; std::cin >> n >> q; std::vector<int> a(n + 1), b(n + 1); for(int i = 1; i <= n; i++) { std::cin >> a[i] >> b[i]; } std::vector<int> x(q + 1); for(int i = 1; i <= q; i++) { std::cin >> x[i]; } std::vector<int> t(n + 1); for(int i = 1; i <= n; i++) { if(a[i] > b[i]) { t[i] = 1; std::swap(a[i], b[i]); } } std::vector<int> compres; for(int i = 1; i <= n; i++) { compres.push_back(a[i]); compres.push_back(b[i]); } for(int i = 1; i <= q; i++) { compres.push_back(x[i]); } std::sort(compres.begin(), compres.end()); compres.erase(unique(compres.begin(), compres.end()), compres.end()); std::vector<int> fa(n + 1); std::vector<int> fb(n + 1); std::vector<int> fx(q + 1); for(int i = 1; i <= n; i++) { fa[i] = lower_bound(compres.begin(), compres.end(), a[i]) - compres.begin() + 1; fb[i] = lower_bound(compres.begin(), compres.end(), b[i]) - compres.begin() + 1; } for(int i = 1; i <= q; i++) { fx[i] = lower_bound(compres.begin(), compres.end(), x[i]) - compres.begin() + 1; } for(int i = 1; i <= q; i++) { seg.update(1, 1, N, fx[i], i); } std::vector<std::array<int, 2>> query[q + 1]; for(int i = 1; i <= n; i++) { int pos = seg.query(1, 1, N, fa[i], fb[i] - 1); if(pos != 0) { t[i] = 1; } pos += 1; if(pos <= q) query[pos].push_back({fb[i], i}); } for(int i = q; i >= 1; i--) { fenw.update(fx[i], 1); for(auto [value, pos] : query[i]) { t[pos] += fenw.query(value, N); } } int ans = 0; for(int i = 1; i <= n; i++) { ans += (t[i] % 2 == 0 ? a[i] : b[i]); } std::cout << ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...