Submission #95922

#TimeUsernameProblemLanguageResultExecution timeMemory
95922oolimrySafety (NOI18_safety)C++14
100 / 100
75 ms5152 KiB
#include <bits/stdc++.h> using namespace std; int main() { ios_base::sync_with_stdio(false); //freopen("i.txt","r",stdin); cin.tie(0); long long n, h; cin >> n >> h; long long arr[n]; for(int i = 0;i < n;i++){ cin >> arr[i]; } priority_queue<long long> left; priority_queue<long long, vector<long long>, greater<long long> > right; left.push(arr[0]); right.push(arr[0]); int prel = arr[0]; int prer = arr[0]; long long acc = 0; for(int i = 1;i < n;i++){ long long shift = i * h; long long l = left.top() - shift; long long r = right.top() + shift; long long x = arr[i]; if(x >= r){ right.push(x - shift); right.push(x - shift); long long y = right.top(); right.pop(); left.push(y + 2 * shift); acc += abs(x - (left.top() - shift)); } else if(x <= l){ left.push(x + shift); left.push(x + shift); long long y = left.top(); left.pop(); right.push(y - 2 * shift); acc += abs(x - (right.top() + shift)); } else{ left.push(x + shift); right.push(x - shift); } l = left.top() - shift; r = right.top() + shift; /* if(prel <= x && x <= prer) acc += 0; else{ acc += min(abs(x-prel),abs(x-prer)); } */ //cout << l << " " << r << endl; prel = l; prer = r; } cout << acc; return 0; }

Compilation message (stderr)

safety.cpp: In function 'int main()':
safety.cpp:21:9: warning: variable 'prel' set but not used [-Wunused-but-set-variable]
     int prel = arr[0];
         ^~~~
safety.cpp:22:9: warning: variable 'prer' set but not used [-Wunused-but-set-variable]
     int prer = arr[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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...