This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define PUB push_back
struct art{
    ll sz, val;
};
int N;
ll pref[500005], ans = 0;
vector<art> data;
bool comp(art a, art b){
    if(a.sz == b.sz) return a.val < b.val;
    return a.sz < b.sz;
}
int main(){
    cin >> N;
    data.PUB({0,0});
    for(int i=1;i<=N;i++){
        ll a, b;
        cin >> a >> b;
        data.PUB({a, b});
    }
    sort(data.begin(), data.end(), comp);
    for(int i=1;i<=N;i++) pref[i] = pref[i-1]+data[i].val;
    
    int l=1;
    ll bef=0;
    for(int i=1;i<=N;i++){
        ll tmp = (pref[i]-pref[l-1])-(data[i].sz-data[l].sz);
        
        if(bef > tmp){
            l=i;
            tmp = (pref[i]-pref[l-1])-(data[i].sz-data[l].sz);
        }
        
        bef = tmp;
        ans = max(ans, tmp);
    }
    
    cout << ans << endl;
}
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... |