This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
#ifdef LOCAL
#include "algo/debug.h"
#else
#define debug(...) 42
#endif
using i64 = long long;
struct Tree {
typedef i64 T;
static constexpr T unit = 1e16;
T f(T a, T b) { return min(a, b); } // (any associative fn)
vector<T> s;
int n;
Tree(int n = 0, T def = unit) : s(2 * n, def), n(n) {}
void update(int pos, T val) {
for (s[pos += n] = val; pos /= 2;)
s[pos] = f(s[pos * 2], s[pos * 2 + 1]);
}
T query(int b, int e) { // query [b, e)
T ra = unit, rb = unit;
for (b += n, e += n; b < e; b /= 2, e /= 2) {
if (b % 2)
ra = f(ra, s[b++]);
if (e % 2)
rb = f(s[--e], rb);
}
return f(ra, rb);
}
};
const int N = 1e5 + 10;
i64 dp[N][110]; // min val khi chia i phan tu vao j nhom
i64 a[N], pm[N];
void solve() {
int n, k;
cin >> n >> k;
for (int i = 1; i <= n; i++) {
cin >> a[i];
pm[i] = max(pm[i - 1], a[i]);
}
memset(dp, 127, sizeof dp);
for (int i = 1; i <= n; i++) {
dp[i][1] = pm[i];
}
vector<int> l(n + 10);
{
stack<int> st;
for (int i = 1; i <= n; i++) {
while (!st.empty() && a[st.top()] <= a[i]) {
st.pop();
}
if (st.empty())
l[i] = 0;
else
l[i] = st.top();
st.push(i);
}
}
for (int j = 2; j <= k; j++) {
Tree st(n + 10);
for (int i = 1; i <= n; i++) {
st.update(i, dp[i][j - 1]);
}
for (int i = j; i <= n; i++) {
dp[i][j] = min(dp[i][j], st.query(l[i] - 1, i) + a[i]);
debug(l[i] + 1, i, dp[i][j], st.query(l[i] - 1, i + 1));
}
}
cout << dp[n][k];
}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int TC = 1;
// cin >> TC;
while (TC--) {
solve();
}
}
Compilation message (stderr)
blocks.cpp: In function 'void solve()':
blocks.cpp:8:20: warning: statement has no effect [-Wunused-value]
8 | #define debug(...) 42
| ^~
blocks.cpp:72:7: note: in expansion of macro 'debug'
72 | debug(l[i] + 1, i, dp[i][j], st.query(l[i] - 1, i + 1));
| ^~~~~
# | 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... |