이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "boxes.h"
#include <bits/stdc++.h>
using namespace std;
long long dp[1000100];
long long delivery(int N, int K, int L, int p[]) {
int mid = L/2;
int lstPos = -1;
for (int i = 1; i <= N; i++){
dp[i] = 1e18;
bool bb = 0;
int pos = p[i-1];
if (lstPos == -1 && pos >= mid)
lstPos = i;
int pos2 = p[max(0, i-K)];
if ((pos2 <= mid && pos <= mid) || (pos2 >= mid && pos >= mid) ){
dp[i] = min(dp[i], dp[max(0, i-K)] + max(min(pos2, L-pos2), min(pos, L-pos))*2 );
} else {
dp[i] = min(dp[i], dp[max(0, i-K)] + L);
dp[i] = min(dp[i], dp[lstPos-1] + max(min(p[lstPos-1], L-p[lstPos-1]), min(pos, L-pos))*2 );
}
//cout << i << ' ' << dp[i] << endl;
/*for (int j = 1; j <= K; j++){
if (i-j < 0)
break;
int pos2 = p[i-j];
if (mid != pos2 && mid != pos && (mid-pos2)/abs(mid-pos2) != (mid-pos)/abs(mid-pos) ){
bb = 1;
}
if (bb){
dp[i] = min(dp[i], dp[i-j] + L);
} else {
dp[i] = min(dp[i], dp[i-j] + max(min(pos2, L-pos2), min(pos, L-pos))*2);
}
}*/
}
return dp[N];
}
컴파일 시 표준 에러 (stderr) 메시지
boxes.cpp: In function 'long long int delivery(int, int, int, int*)':
boxes.cpp:13:14: warning: unused variable 'bb' [-Wunused-variable]
bool bb = 0;
^~
# | 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... |