Submission #476573

#TimeUsernameProblemLanguageResultExecution timeMemory
476573idiot123Potatoes and fertilizers (LMIO19_bulves)C++14
30 / 100
1092 ms27580 KiB
#include<bits/stdc++.h> using namespace std; int main(){ int N; cin>>N; vector<long long> t(N); for(int i = 0; i < N; i++){ int a, b; cin>>a>>b; t[i] = a - b; } priority_queue<long long, vector<long long>, greater<long long>> q; for(int i = 0; i < 2*N; i++)q.push(0); long long shift = 0; long long val = 0; for(int i = 1; i <= N; i++){ //wywalamy pierwszy punkt q.pop(); //przesuwamy shift += t[i-1]; //pobieramy pozycje pierwszego punktu long long x = q.top() + shift; if(x <= 0){ val += abs(x); q.push(-shift); q.push(-shift); }else{ q.push(-shift); q.push(-shift); } } long long x = q.top() + shift; long long result; if(x >= 0){ result = val + x; }else{ result = val; int slope = 0; q.pop(); while(q.top() + shift <= 0){ result += slope * (q.top() + shift - x); x = q.top() + shift; q.pop(); slope++; } result += slope *(0 - x); } cout<<result; 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...
#Verdict Execution timeMemoryGrader output
Fetching results...