Submission #704452

#TimeUsernameProblemLanguageResultExecution timeMemory
704452GrandTiger1729Art Exhibition (JOI18_art)C++17
100 / 100
231 ms24380 KiB
#include <iostream> #include <algorithm> #include <queue> using namespace std; const long long INF = 1e18; int main(){ cin.tie(0)->sync_with_stdio(0); int n; cin >> n; pair<long long, long long> a[n]; for (int i = 0; i < n; i++) cin >> a[i].first >> a[i].second; sort(a, a + n); long long pref[n + 1]{}; for (int i = 0; i < n; i++) pref[i + 1] = pref[i] + a[i].second; priority_queue<long long, vector<long long>, greater<long long>> pq; long long ans = -INF; for (int i = 0; i < n; i++){ pq.push(pref[i] - a[i].first); ans = max(ans, pref[i + 1] - a[i].first - pq.top()); } cout << ans << '\n'; 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...