Submission #226538

#TimeUsernameProblemLanguageResultExecution timeMemory
226538sevlllSplit the sequence (APIO14_sequence)C++14
0 / 100
246 ms89308 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]; pair<ll, ll> intersec(tuple<ld, ld, int> w1, tuple<ld, ld, int> w2) { ld k1 = get<0>(w1), b1 = get<1>(w1); ld k2 = get<0>(w2), b2 = get<1>(w2); return {b2 - b1, k1 - k2}; } vector<tuple<ld, ld, int>> s; void add_line(ld k, ld b, int index) { while (s.size() >= 2) { pair<ll, ll> x1 = intersec(s[s.size() - 2], s[s.size() - 1]); pair<ll, ll> x2 = intersec(s[s.size() - 2], {k, b, index}); if (x1.first * x2.second >= x2.first * x1.second) { 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; pair<ll, ll> lol = intersec(s[mid - 1], s[mid]); if (lol.first >= h * lol.second) { 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((ld) pref[t], (ld) C[t], t); for (int i = t + 1; i <= n; i++) { pair<ll, int> kek = my_lower_bound(pref[i]); add_line((ld) pref[i], (ld) 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...