Submission #226541

#TimeUsernameProblemLanguageResultExecution timeMemory
226541sevlllSplit the sequence (APIO14_sequence)C++14
71 / 100
2101 ms87912 KiB
// #define _GLIBCXX_DEBUG #include <iostream> #include <iomanip> #include <cstdio> #include <cstdlib> #include <algorithm> #include <cmath> #include <vector> #include <set> #include <map> #include <unordered_set> #include <unordered_map> #include <queue> #include <ctime> #include <cassert> #include <complex> #include <string> #include <cstring> #include <random> #include <queue> #include <bitset> // #define int long long #define ll long long #define ld long double #define pb push_back #define str string using namespace std; const int M = 998244353; ll dp[100009]; ll C[100009]; int par[100009][209]; ld intersec(tuple<ll, ll, int> w1, tuple<ll, ll, int> w2) { ld k1 = get<0>(w1), b1 = get<1>(w1); ld k2 = get<0>(w2), b2 = get<1>(w2); ld x = (b2 - b1) / (k1 - k2); return x; } vector<tuple<ll, ll, int>> s; void add_line(ll k, ll b, int index) { while (s.size() >= 2) { ld x1 = intersec(s[s.size() - 2], s[s.size() - 1]); ld x2 = intersec(s[s.size() - 2], {k, b, index}); if (x1 >= x2) { s.pop_back(); } else { break; } } s.pb({k, b, index}); } pair<ll, int> my_lower_bound(ll h) { int left = 0; int right = (int) s.size(); while (right - left > 1) { int mid = (left + right) / 2; ld lol = intersec(s[mid - 1], s[mid]); if (lol >= h) { right = mid; } else { left = mid; } } return {h * get<0> (s[left]) + get<1>(s[left]), get<2>(s[left])}; } signed main() { ios::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr); int n, k; cin >> n >> k; vector<ll> A(n + 1); for (int i = 1; i <= n; i++) cin >> A[i]; vector<ll> pref = A; for (int i = 1; i <= n; i++) pref[i] += pref[i - 1]; for (int i = 1; i <= n; i++) { dp[i] = 0; C[i] = -pref[i] * pref[i]; } for (int t = 1; t <= k; t++) { add_line(pref[t], C[t], t); for (int i = t + 1; i <= n; i++) { pair<ll, int> kek = my_lower_bound(pref[i]); add_line(pref[i], C[i], i); dp[i] = kek.first; par[i][t] = kek.second; C[i] = dp[i] - pref[i] * pref[i]; } s = {}; } cout << dp[n] << '\n'; int i = n; int t = k; vector<ll> ans; while (t >= 1) { cout << par[i][t] << ' '; i = par[i][t]; t--; } }
#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...