#include using namespace std; struct iofast_t { iofast_t() { ios::sync_with_stdio(false); cin.tie(nullptr); } } iofast; struct uns_t {} uns; template auto vec(Element init, Head arg, Args ...args) { if constexpr (sizeof...(Args) == 0) return std::vector(arg, init); else return std::vector(arg, vec(init, args...)); } template auto vec(uns_t, Head arg, Args ...args) { return vec(Element(), arg, args...); } template > T &chmin(T &l, T r, Compare &&f = less()) { return l = min(l, r, f); } template > T &chmax(T &l, T r, Compare &&f = less()) { return l = max(l, r, f); } int main() { constexpr int64_t inf = INT64_MAX / 4; constexpr auto inv = make_tuple(-1, -1, -1); int n, m; cin >> n >> m; auto a = vec(uns, n); for (auto &e : a) cin >> e; reverse(begin(a), end(a)); auto dp = vec>({ +inf, -inf }, n + 1, m + 1); auto prev = vec, 2>>(uns, n + 1, m + 1); for (int j = 0; j <= m; ++j) { dp[0][j][0] = dp[0][j][1] = 0; prev[0][j][0] = prev[0][j][1] = inv; } int64_t sum = 0; for (int i = 1; i <= n; ++i) { int c = a[i - 1]; sum += c; dp[i][0][0] = dp[i][0][1] = sum; prev[i][0][0] = prev[i][0][1] = inv; int64_t l0 = dp[i - 1][0][0], r0 = dp[i - 1][0][1]; int64_t l1 = +inf, r1 = -inf; auto pl0 = make_tuple(i - 1, 0, 0); auto pr0 = make_tuple(i - 1, 0, 1); auto pl1 = inv; auto pr1 = inv; for (int j = 1; j <= m; ++j) { dp[i][j][0] = dp[i - 1][j][0] + c; dp[i][j][1] = dp[i - 1][j][1] + c; prev[i][j][0] = make_tuple(i - 1, j, 0); prev[i][j][1] = make_tuple(i - 1, j, 1); if (2 <= j) { if (j % 2 == 0) { if (+l0 + c < dp[i][j][0]) { prev[i][j][0] = pl0; } if (+r0 + c > dp[i][j][1]) { prev[i][j][1] = pr0; } chmin(dp[i][j][0], +l0 + c); chmax(dp[i][j][1], +r0 + c); } else { if (+l1 + c < dp[i][j][0]) { prev[i][j][0] = pl1; } if (+r1 + c > dp[i][j][1]) { prev[i][j][1] = pr1; } chmin(dp[i][j][0], +l1 + c); chmax(dp[i][j][1], +r1 + c); } } if (1 <= j) { if (j % 2 == 0) { if (-r1 - c < dp[i][j][0]) { prev[i][j][0] = pr1; } if (-l1 - c > dp[i][j][1]) { prev[i][j][1] = pl1; } chmin(dp[i][j][0], -r1 - c); chmax(dp[i][j][1], -l1 - c); } else { if (-r0 - c < dp[i][j][0]) { prev[i][j][0] = pr0; } if (-l0 - c > dp[i][j][1]) { prev[i][j][1] = pl0; } chmin(dp[i][j][0], -r0 - c); chmax(dp[i][j][1], -l0 - c); } } if (j % 2 == 0) { if (dp[i - 1][j][0] < l0) { pl0 = make_tuple(i - 1, j, 0); } if (dp[i - 1][j][0] > r0) { pr0 = make_tuple(i - 1, j, 1); } chmin(l0, dp[i - 1][j][0]); chmax(r0, dp[i - 1][j][1]); } else { if (dp[i - 1][j][0] < l1) { pl1 = make_tuple(i - 1, j, 0); } if (dp[i - 1][j][0] > r1) { pr1 = make_tuple(i - 1, j, 1); } chmin(l1, dp[i - 1][j][0]); chmax(r1, dp[i - 1][j][1]); } } } auto ans = vec(uns, 0); auto solve = [&](auto &&self, int i, int j, int k) -> void { auto p = prev[i][j][k]; if (p == inv) { while (j--) { ans.push_back(i); } return; } auto [pi, pj, pk] = p; if (pj < j) { ans.push_back(i); } self(self, pi, pj, pk); }; solve(solve, n, m, 1); for (auto v : ans) { cout << n - v << endl; } }