Submission #526050

#TimeUsernameProblemLanguageResultExecution timeMemory
526050two_sidesTwo Dishes (JOI19_dishes)C++17
100 / 100
3349 ms225548 KiB
#include <bits/stdc++.h> using namespace std; #define il i * 2 #define ir i * 2 + 1 using ll = long long; const int N = 1000005; ll a[N], b[N], sa[N], sb[N], ca[N], cb[N]; vector<int> pos[N]; ll val[N * 4], tag[N * 4], res; int lo, hi, n, m, far[N]; void apply(int i, ll v) { val[i] += v; tag[i] += v; } void push(int i) { apply(il, tag[i]); apply(ir, tag[i]); tag[i] = 0; } void add(int i, int l, int r, ll v) { if (l >= lo && r <= hi) return apply(i, v); int m = (l + r) / 2; push(i); if (m >= lo) add(il, l, m, v); if (m < hi) add(ir, m + 1, r, v); val[i] = max(val[il], val[ir]); } void assign(int i, int l, int r, ll v) { if (l == r) { val[i] = v; return; } int m = (l + r) / 2; push(i); if (m >= lo) assign(il, l, m, v); else assign(ir, m + 1, r, v); val[i] = max(val[il], val[ir]); } void get(int i, int l, int r) { if (l >= lo && r <= hi) { res = max(res, val[i]); return; } int m = (l + r) / 2; push(i); if (m >= lo) get(il, l, m); if (m < hi) get(ir, m + 1, r); } void add(int l, int r, ll v) { lo = l; hi = r; add(1, 0, m, v); } void assign(int p, ll v) { lo = p; assign(1, 0, m, v); } ll get(int l, int r) { lo = l; hi = r; res = -1e18; get(1, 0, m); return res; } int main() { cin.tie(0)->sync_with_stdio(0); cin >> n >> m; for (int i = 1; i <= n; i++) { cin >> a[i] >> sa[i] >> ca[i]; a[i] += a[i - 1]; } for (int i = 1; i <= m; i++) { cin >> b[i] >> sb[i] >> cb[i]; b[i] += b[i - 1]; } for (int i = 1; i <= m; i++) { int x = -1, y = n; while (x < y) { int z = (x + y + 1) / 2; if (b[i] + a[z] <= sb[i]) x = z; else y = z - 1; } if (x >= 0) pos[x].push_back(i); } long long ans = 0; for (int i = 1; i <= n; i++) { int x = -1, y = m; while (x < y) { int z = (x + y + 1) / 2; if (a[i] + b[z] <= sa[i]) x = z; else y = z - 1; } if ((far[i] = x) >= 0) ans += ca[i]; } memset(val, 0xc0, sizeof val); assign(0, 0); for (int i = 0; i <= n; i++) { if (i < n && far[i + 1] >= 0 && far[i + 1] < m) { ll v = get(0, far[i + 1] + 1); assign(far[i + 1] + 1, v); } for (int k : pos[i]) { ll v = get(0, k); assign(k, v); } if (i == n) assign(m, val[1]); if (i < n && far[i + 1] >= 0 && far[i + 1] < m) add(far[i + 1] + 1, m, -ca[i + 1]); for (int k : pos[i]) add(k, m, cb[k]); } cout << get(m, m) + ans << '\n'; }
#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...