이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#define fi first
#define se second
using namespace std;
typedef long long ll;
int n;
pair<ll, int> v[500002];
ll sp[500002], mxx[500002];
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin >> n;
for(int i = 1; i <= n; ++i)
cin >> v[i].fi >> v[i].se;
sort(v + 1, v + n + 1);
for(int i = 1; i <= n; ++i)
{
sp[i] = sp[i-1] + v[i-1].fi + v[i].se - v[i].fi;
// cout << sp[i] << " ";
}
// cout << '\n';
mxx[n] = sp[n];
for(int i = n-1; i >= 1; --i)
mxx[i] = max(mxx[i+1], sp[i]);
ll ans = 0;
for(int i = 1; i <= n; ++i)
{
// cout << mxx[i] + v[i].fi << " " << - sp[i-1] - v[i-1].fi << '\n';
ans = max(ans, mxx[i] + v[i].fi - sp[i-1] - v[i-1].fi);
}
cout << ans;
return 0;
}
# | 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... |