이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "boxes.h"
#include <bits/stdc++.h>
using namespace std;
long long delivery(int N, int K, int L, int p[]) {
vector<long long> dp1,dp2;
vector<long long> suf;
dp1.resize(N);
dp2.resize(N);
dp1[0] = 2ll*p[0];
for(int i = 1; i < N; i++){
dp1[i] = i >= K ? dp1[i-K] : 0ll;
dp1[i] += 2ll*(long long)p[i];
}
dp2[N-1] = 2ll*(long long)(L-p[N-1]);
for(int i = N-2; i >= 0; i--){
dp2[i] = i+K >= N ? 0ll : dp2[i+K];
dp2[i] += 2ll*(long long)(L-p[i]);
}
long long mn = (long long)(N+K-1)/(long long)K*(long long)L;
for(int i = 0; i < N; i++){
mn = min(mn,dp1[i] + (long long)(N-i+K-2)/(long long)K*(long long)L);
mn = min(mn,dp2[i] + (long long)(i+K-1)/(long long)K*(long long)L);
}
for(int i = 0; i < K; i++){
suf.clear();
for(int j = (N-i-1)/K; j >= 0; j--) suf.push_back(0);
for(int j = (N-i-1)/K; j >= 0; j--){
suf[j] = min((K*(j+1)+i >= N ? (long long)1e18 : suf[j+1]),dp2[K*j+i] + (long long)j*(long long)L);
}
for(int j = (N-i-1)/K; j >= 0; j--){
mn = min(mn,dp1[i+j*K-1] + suf[j] - (long long)(i+j*K)/(long long)K*(long long)L);
}
}
return mn;
}
# | 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... |