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>
#include "boxes.h"
using namespace std;
const int N = 10000002;
long long dp[N], dp2[N], poz[N];
long long delivery (int n, int k, int l, int meh[]) {
for (int i = 1; i <= n; i++)
poz[i] = meh[i - 1];
for (int i = 1; i <= n; i++)
dp[i] = (i >= k ? dp[i - k] + 2 * poz[i] : 2 * poz[i]);
for (int i = n; i >= 1; i--)
dp2[i] = (i <= n - k ? dp2[i + k] + 2 * (l - poz[i]) : 2 * (l - poz[i]));
long long ans = 1e18;
for (int i = 0; i <= n; i++)
ans =min(ans, dp[i] + dp2[i + 1]);
for (int i = 0; i <= n - k; i++)
ans = min(ans, dp[i] + dp2[i + k + 1] + l);
return ans;
}
/*int main () {
int aux[] = {1, 2, 5};
cout << delivery(3, 2, 8, aux) << "\n";
}*/
# | 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... |