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 <bits/stdc++.h>
#define pb push_back
#define F first
#define S second
using namespace std;
using ll = long long int;
using pll = pair<ll, ll>;
ll delivery(int N, int K, int L, int p[]) {
ll dp[N + 2], pd[N + 2], ans = 1e18;
vector<ll> vec = {-1};
deque<pll> st;
for(int i = 0; i < N; i++) if(p[i]) vec.pb(p[i]);
dp[0] = pd[vec.size()] = 0;
st.push_back({0, 0});
for(int i = 1; i < (int)vec.size(); i++){
while(st.front().S < i - K) st.pop_front();
dp[i] = st.front().F + vec[i] + min(vec[i], L - vec[i]);
while(st.back().F > dp[i]) st.pop_back();
st.push_back({dp[i], i});
}
st.clear();
st.push_back({0, vec.size()});
for(int i = (int)vec.size() - 1; i; i--){
while(st.front().S > i + K) st.pop_front();
pd[i] = st.front().F + L - vec[i] + min(vec[i], L - vec[i]);
while(st.back().F > pd[i]) st.pop_back();
st.push_back({pd[i], i});
}
for(ll i = 0; i < (int)vec.size(); i++) ans = min(ans, dp[i] + pd[i + 1]);
return ans;
}
# | 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... |