Submission #580357

#TimeUsernameProblemLanguageResultExecution timeMemory
580357alirezasamimi100Boxes with souvenirs (IOI15_boxes)C++17
100 / 100
825 ms425168 KiB
#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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...