# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
580355 | alirezasamimi100 | 선물상자 (IOI15_boxes) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#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};
priority_queue<pll, vector<pll>, greater<pll>> st;
for(int i = 0; i < N; i++) if(p[i]) vec.pb(p[i]);
dp[0] = pd[vec.size()] = 0;
st.push({0, 0});
for(int i = 1; i < (int)vec.size(); i++){
while(st.top().S < i - K) st.pop();
dp[i] = st.top().F + vec[i] + min(vec[i], L - vec[i]);
st.push({dp[i], i});
}
st.clear();
st.push({0, vec.size()});
for(int i = (int)vec.size() - 1; i; i--){
while(st.top().S > i + K) st.pop();
pd[i] = st.top().F + L - vec[i] + min(vec[i], L - vec[i]);
st.push({pd[i], i});
}
for(ll i = 0; i < (int)vec.size(); i++) ans = min(ans, dp[i] + pd[i + 1]);
return ans;
}