Submission #800616

#TimeUsernameProblemLanguageResultExecution timeMemory
800616happypotatoBoxes with souvenirs (IOI15_boxes)C++17
10 / 100
1 ms212 KiB
#include "boxes.h" #include <bits/stdc++.h> using namespace std; #define int long long #define pii pair<int, int> #define ff first #define ss second #define pb push_back int n, k, l; vector<int> v; int st1() { int ans = 0; for (int i = 1; i <= n; i++) ans += min(l, min(v[i], l - v[i]) * 2); return ans; } int st2() { int ans = min(l, min(v[n], l - v[1]) * 2); // ??? cerr << ans << endl; return ans; } long long delivery(int32_t N, int32_t K, int32_t L, int32_t p[]) { l = L; v.clear(); v.pb(-1); for (int i = 0; i < N; i++) if (p[i] > 0) v.pb(p[i]); sort(v.begin(), v.end()); n = (int)(v.size()) - 1; k = min((int)(K), n); if (n == 0) return 0; if (k == 1) return st1(); if (k == n) return st2(); } #undef int /* subtasks 1-3 trivial subtask 4 should be O(n^2) left-right dp */

Compilation message (stderr)

boxes.cpp: In function 'long long int delivery(int32_t, int32_t, int32_t, int32_t*)':
boxes.cpp:30:1: warning: control reaches end of non-void function [-Wreturn-type]
   30 | }
      | ^
#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...