Submission #1126175

#TimeUsernameProblemLanguageResultExecution timeMemory
1126175OI_AccountTwo Dishes (JOI19_dishes)C++20
100 / 100
4907 ms199804 KiB
#include <bits/stdc++.h>
using namespace std;

typedef long long ll;

const int N = 1'000'100;
const ll INF = 1'000'000'000'000'000'000;

int n, m, s[N + 10], t[N + 10];
ll a[N + 10], c[N + 10], x[N + 10];
ll b[N + 10], d[N + 10], y[N + 10];
ll sumA[N + 10], sumB[N + 10];
ll add[4 * N + 10], lazy[4 * N + 10];
vector<pair<int, pair<int, ll>>> vec[N + 10];

void readInput() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        cin >> a[i] >> x[i] >> c[i];
        sumA[i] = sumA[i - 1] + a[i];
    }
    for (int i = 1; i <= m; i++) {
        cin >> b[i] >> y[i] >> d[i];
        sumB[i] = sumB[i - 1] + b[i];
    }
}

void init() {
    for (int i = 1; i <= n; i++) {
        s[i] = upper_bound(sumB, sumB + m + 1, x[i] - sumA[i]) - sumB - 1;
        if (s[i] != -1)
            vec[i - 1].push_back({0, {s[i], c[i]}});
        //cout << "s " << i << " = " << s[i] << endl;
    }
    for (int i = 1; i <= m; i++) {
        t[i] = upper_bound(sumA, sumA + n + 1, y[i] - sumB[i]) - sumA - 1;
        if (t[i] != -1)
            vec[t[i]].push_back({1, {i, d[i]}});
        //cout << "t " << i << " = " << t[i] << endl;
    }
}

void shift(int, int, int);

ll get(int idx, int id = 1, int l = 0, int r = m + 1) {
    if (l + 1 == r)
        return max(add[id], lazy[id]);
    shift(id, l, r);
    int mid = (l + r) >> 1;
    if (idx < mid)
        return get(idx, id << 1, l, mid);
    return get(idx, id << 1 | 1, mid, r);
}

void updateAdd(int st, int en, ll val, int id = 1, int l = 0, int r = m + 1) {
    if (en <= l || r <= st)
        return;
    if (st <= l && r <= en) {
        add[id] += val;
        if (lazy[id] != -INF)
            lazy[id] += val;
        return;
    }
    shift(id, l, r);
    int mid = (l + r) >> 1;
    updateAdd(st, en, val, id << 1, l, mid);
    updateAdd(st, en, val, id << 1 | 1, mid, r);
}

void updateMax(int st, int en, ll val, int id = 1, int l = 0, int r = m + 1) {
    if (en <= l || r <= st)
        return;
    if (st <= l && r <= en) {
        lazy[id] = max(lazy[id], val);
        return;
    }
    shift(id, l, r);
    int mid = (l + r) >> 1;
    updateMax(st, en, val, id << 1, l, mid);
    updateMax(st, en, val, id << 1 | 1, mid, r);
}

void shiftAdd(int id, int l, int r) {
    if (!add[id])
        return;
    int mid = (l + r) >> 1;
    updateAdd(l, r, add[id], id << 1, l, mid);
    updateAdd(l, r, add[id], id << 1 | 1, mid, r);
    add[id] = 0;
}

void shiftMax(int id, int l, int r) {
    if (lazy[id] == -INF)
        return;
    int mid = (l + r) >> 1;
    updateMax(l, r, lazy[id], id << 1, l, mid);
    updateMax(l, r, lazy[id], id << 1 | 1, mid, r);
    lazy[id] = -INF;
}

void shift(int id, int l, int r) {
    shiftAdd(id, l, r);
    shiftMax(id, l, r);
}

void addVec(int i) {
    for (auto [type, p]: vec[i])
        if (type == 0)
            updateAdd(0, p.first + 1, p.second);
        else
            updateAdd(p.first, m + 1, p.second);
}

void maxVec(int i) {
    for (auto [type, p]: vec[i]) {
        int idx = p.first - type;
        //cout << idx << ' ' << get(idx) << endl;
        updateMax(idx, m + 1, get(idx));
    }
}

void calcDP() {
    for (int i = 0; i <= n; i++) {
        addVec(i);
        /*cout << i << " -> ";
        for (int j = 0; j <= m; j++)
            cout << get(j) << ' ';
        cout << endl;*/
        if (i != n)
            maxVec(i);
        /*cout << i << " -> ";
        for (int j = 0; j <= m; j++)
            cout << get(j) << ' ';
        cout << endl;*/
    }
}

int main() {
    ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0);
    readInput();
    init();
    calcDP();
    cout << get(m) << flush;
    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...