Submission #1267242

#TimeUsernameProblemLanguageResultExecution timeMemory
1267242codefoxArt Exhibition (JOI18_art)C++20
100 / 100
247 ms43500 KiB
#include<bits/stdc++.h>

using namespace std;


#define int long long
#define pii pair<int, int>

int32_t main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);

    //freopen("../input.txt", "r", stdin);
    //freopen("../output.txt", "w", stdout);

    int n;
    cin >> n;
    n++;
    vector<int> pref(n, 0);
    multiset<int> pp;
    vector<pii> ab(n);
    vector<int> a(n);
    vector<int> b(n);
    for (int i = 1; i < n; i++)
    {
        cin >> ab[i].first >> ab[i].second;
    }
    sort(ab.begin(), ab.end());
    for (int i = 1; i < n; i++)
    {
        a[i] = ab[i].first;
        b[i] = ab[i].second; 
    }
    for (int i = 1; i < n; i++)
    {
        pref[i] = pref[i-1]+b[i];
        pp.insert(pref[i]-a[i]);
    }
    pp.insert(pref[n-1]-a[n-1]);
    int ans = -1e17;
    for (int i= 1; i < n; i++)
    {
        int sol = -pref[i-1]+a[i];
        sol+=*(--pp.end());
        pp.erase(pp.find(pref[i]-a[i]));
        ans = max(ans, sol);
    }
    cout << ans << endl;

    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...