Submission #102557

#TimeUsernameProblemLanguageResultExecution timeMemory
102557OrtSimfonija (COCI19_simfonija)C++11
110 / 110
140 ms6156 KiB
#include<iostream> #include<vector> #include<algorithm> #include<ext/pb_ds/assoc_container.hpp> #include<ext/pb_ds/tree_policy.hpp> #include<functional> #define MAX 100020 #define ll long long using namespace __gnu_pbds; using namespace std; typedef tree<int, null_type, less_equal<int>, rb_tree_tag, tree_order_statistics_node_update> ordered_set; ordered_set o; int n, k, x; ll sol = 100000000000000000; int a[MAX]; int main() { cin.sync_with_stdio(0); cin.tie(0); cin.exceptions(cin.failbit); cin >> n >> x; k = n - x; for(int i=0;i<n;i++) cin >> a[i]; for(int i=0;i<n;i++) {cin >> x; a[i]-=x;} sort(a, a+n); for(int i=0;i<k;i++) o.insert(a[i]); ll m = 0, c = 0, nc = 0, l, r; if(k%2) m = k / 2; else m = k / 2 - 1; int mv = *(o.find_by_order(m)); for(int i=0;i<k;i++) c += abs(a[i]-mv); ll om = mv; sol = min(sol,c); for(int i=0;i<(n-k);i++) { o.erase(o.find_by_order(o.order_of_key(a[i]))); o.insert(a[i+k]); mv = *(o.find_by_order(m)); l = a[i]; r = a[i+k]; nc = c - (abs(om-l)) + (abs(mv-r)); if(k%2==0) nc -= (mv - om); sol = min(sol,nc); c = nc; om = mv; } cout << sol; 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...
#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...