Submission #748459

#TimeUsernameProblemLanguageResultExecution timeMemory
748459Desh03Art Exhibition (JOI18_art)C++17
100 / 100
209 ms36484 KiB
#include <bits/stdc++.h>
using namespace std;

long long art_exhibition(int n, vector<long long> a, vector<int> b) {
    long long ans = 0;
    vector<pair<long long, int>> v;
    for (int i = 0; i < n; i++) v.push_back({a[i], b[i]});
    sort(v.begin(), v.end());
    vector<long long> pre(n + 1);
    for (int i = 0; i < n; i++) pre[i + 1] = pre[i] + v[i].second;
    for (int i = 0; i < n; i++) pre[i] -= v[i].first;
    long long mn = pre[0];
    for (int i = 1; i <= n; i++) {
        ans = max(ans, pre[i] - mn + (i == n ? 0 : v[i].first) - v[i - 1].first);
        mn = min(mn, pre[i]);
    }
    return ans;
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    int n;
    cin >> n;
    vector<long long> a(n);
    vector<int> b(n);
    for (int i = 0; i < n; i++) cin >> a[i] >> b[i];
    cout << art_exhibition(n, a, b) << '\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...