제출 #238028

#제출 시각아이디문제언어결과실행 시간메모리
238028Kubin선물상자 (IOI15_boxes)C++11
35 / 100
5 ms512 KiB
#include <bits/stdc++.h> using namespace std; long long delivery(int _n, int _k, int l, int p[]) { size_t n = _n, k = _k; vector<int> A[2]; int a = 0; A[0].reserve(n); A[1].reserve(n); for(size_t i = 0; i < n; i++) if(p[i]) { if(2*p[i] == l) a++; else if(p[i] <= l/2) A[0].push_back(p[i]); else A[1].push_back(l - p[i]); } reverse(A[1].begin(), A[1].end()); vector<int64_t> B[2]; for(size_t t = 0; t < 2; t++) { B[t].resize(A[t].size() + a + 1); for(size_t i = 0; i < A[t].size() + a; i++) B[t][i+1] = (i+1 >= k ? B[t][i+1-k] : 0) + (i<A[t].size() ? A[t][i] : l/2); } size_t ni = a + A[0].size() + A[1].size(); int64_t result = ni ? INT64_MAX : 0, base = 0; while(ni) { for(int x = 0; x <= a; x++) { result = min( result, base + 2 * (B[0][A[0].size() + size_t(x)] + B[1][A[1].size() + size_t(a-x)]) ); } for(size_t i = 0; i < k and ni; i++, ni--) { if(a) a--; else if(A[0].empty()) A[1].pop_back(); else if(A[1].empty()) A[0].pop_back(); else { auto d0 = B[0][A[0].size()] - B[0][A[0].size() - 1], d1 = B[1][A[1].size()] - B[1][A[1].size() - 1]; if(d0 < d1) A[1].pop_back(); else A[0].pop_back(); } } base += l; } result = min(result, base); return result; }
#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...