이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "boxes.h"
#include <iostream>
#include <iomanip>
#include <string>
#include <math.h>
#include <algorithm>
#include <cstring>
#include <numeric>
#include <vector>
#include <map>
#include <set>
#include <deque>
#include <unordered_map>
#include <unordered_set>
using namespace std;
typedef long long ll;
#define dbg(x) cerr<<#x<<": "<<x<<"\n";
#define fr(i, x) for(ll i=0 ; i<x ; i++)
#define fra(x, v) for(auto x:v)
#define fra1(x,v) for(auto &x:v)
#define all(x) x.begin(), x.end()
#define allr(x) x.rbegin(), x.rend()
#define pb(x) push_back(x)
#define F first
#define S second
const ll maxN=1e6;
ll dp[maxN], dp1[maxN];
long long delivery(int N, int K, int L, int p[]) {
ll n=N, k=K, l=L;
vector<ll>v(n);
fr(i, n) v[i]=p[i];
deque<pair<ll, ll>>dq;
dq.pb(make_pair(0, -1));
for(ll i=0; i<n ; i++){
if(dq.front().S==i-k-1) dq.pop_front();
dp[i]+=(min(l, 2*v[i]))+dq.front().F;
while(dq.size() && dq.front().F>=dp[i]) dq.pop_front();
dq.pb(make_pair(dp[i], i));
}
dq.clear();
dq.pb(make_pair(0, n));
for(ll i=n-1 ; i>=0 ; i--){
if(dq.front().S==i+k+1)dq.pop_front();
dp1[i]+=(min(l, 2*(l-v[i])))+dq.front().F;
while(dq.size() && dq.front().F>=dp1[i]) dq.pop_front();
dq.pb(make_pair(dp1[i], i));
}
// fr(i, n) cout<<dp[i]<<" "<<dp1[i]<<"\n";
ll ans=1e18;
for(ll i=0 ; i<n ; i++){
ans=min(ans, dp[i]+dp1[(i+1)%n]);
}
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... |