This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define ff(i,a,b) for(int (i) = (a); (i) <= (b); ++(i))
#define fb(i,a,b) for(int (i) = (a); (i) >= (b); --(i))
#include "boxes.h"
#define maxn 10000005
using namespace std;
typedef long long ll;
int n,k;
int niz[maxn];
int d;
set<int>s;
ll dist(int l, int r){
if(l > r)swap(l, r);
ll res = min(r - l, l + d - r);
return res;
}
ll levi[maxn];
ll desni[maxn];
long long delivery(int N, int K, int L, int p[]) {
n = N, k = K, d = L;
ff(i,1,n)niz[i] = p[i - 1];
sort(niz + 1, niz + 1 + n);
levi[0] = 0;
desni[n + 1] = 0;
ff(i,1,n){
if(i > k){
levi[i] = levi[i - k] + 2 * niz[i];
}
else levi[i] = 2 * niz[i];
continue;
if(k == 1 || i%k == 1){
levi[i] = levi[i - 1] + 2*niz[i];
}
else{
levi[i] = levi[i - 1] - niz[i - 1] + niz[i] - niz[i - 1] + niz[i];
}
}
fb(i,n,1){
int kol = n - i + 1;
if(kol > k){
desni[i] = desni[i + k] + 2*(d - niz[i]);
}
else desni[i] = 2*(d - niz[i]);
continue;
if(kol%k == 1 || k == 1){
desni[i] = desni[i + 1] + 2*(d-niz[i]);
//cout << i << " " << desni[i] << endl;
//exit(0);
}
else{
desni[i] = desni[i + 1] - (d-niz[i + 1]) + (d-niz[i]) - (d-niz[i + 1]) + (d-niz[i]);
}
}
ll res = levi[0] + desni[1];
ff(i,0,n){
res = min(res, levi[i] + desni[i + 1]);
}
ff(i,1,n){
res = min(res, levi[i - 1] + d + desni[i + k]);
}
return res;
}
/*
int aa[maxn];
int N,K,L;
int main(){
freopen("06", "r", stdin);
cin >> N >> K >> L;
ff(i,0,N - 1)cin >> aa[i];
cout << delivery(N,K,L,aa);
return 0;
}
/*
10 5 1000
7 63 166 821 853 857 930 934 989 995
*/
Compilation message (stderr)
boxes.cpp:74:1: warning: "/*" within comment [-Wcomment]
/*
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |