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 "boxes.h"
#include <vector>
#include <algorithm>
using namespace std;
long long delivery(int N, int K, int L, int p[]) {
sort(p, p + N);
int ls = 0;
for(int i = 0; i < N; ++i) {
if(2 * p[i] < L) ++ls;
}
vector<long long> d(N + 2);
for(int i = 1; i <= ls; ++i) {
d[i] = (i < K ? 0 : d[i - K]) + 2 * p[i - 1];
}
for(int i = 1; i <= N - ls; ++i) {
d[i + ls + 1] = (i < K ? 0 : d[i - K + ls + 1]) + 2 * (L - p[N - i]);
}
long long ret = d[ls] + d[N + 1];
for(int i = ls - K + 1; i <= ls && i <= N - K; ++i) {
int pl = N - K - i + ls + 1;
if(pl < 0 || pl >= N + 2) continue;
ret = min(ret, d[i] + d[N - K - i + ls + 1] + L);
}
return ret;
}
# | 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... |