제출 #1099984

#제출 시각아이디문제언어결과실행 시간메모리
1099984vladilius수열 (APIO14_sequence)C++17
71 / 100
59 ms131072 KiB
#include <bits/stdc++.h> using namespace std; using ll = long long; using pii = pair<int, int>; #define pb push_back #define ff first #define ss second #define ld long double struct CHT{ struct line{ int k, i; ll b; ll operator () (int x){ return 1LL * k * x + b; } }; ld inter(line x, line y){ return (ld) (x.b - y.b) / (y.k - x.k); } deque<line> q; void add(int k, ll b, int i){ line f = {k, i, b}; while (q.size() > 1){ if (q.back().k == f.k){ if (q.back().b <= f.b){ return; } q.pop_back(); continue; } if (inter(q.back(), f) > inter(q[q.size() - 2], f)) break; q.pop_back(); } if (!q.empty() && q.back().k == f.k){ if (q.back().b > f.b){ q.pop_back(); } else { return; } } q.pb(f); } pair<ll, int> get(int x){ while (q.size() > 1 && inter(q[0], q[1]) < x) q.pop_front(); return {q[0](x), q[0].i}; } void clear(){ q.clear(); } }; int main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n, k; cin>>n>>k; vector<int> a(n + 1), p(n + 1); for (int i = 1; i <= n; i++){ cin>>a[i]; p[i] = p[i - 1] + a[i]; } auto sq = [&](int x){ return 1LL * x * x; }; vector<vector<ll>> dp(n + 1, vector<ll>(k + 1)); vector<vector<int>> pr(n + 1, vector<int>(k + 1)); for (int i = 1; i <= n; i++) dp[i][0] = sq(p[i]); CHT T; for (int j = 1; j <= k; j++){ T.clear(); for (int i = j + 1; i <= n; i++){ T.add(-2 * p[i - 1], dp[i - 1][j - 1] + sq(p[i - 1]), i - 1); auto [x, ii] = T.get(p[i]); dp[i][j] = sq(p[i]) + x; pr[i][j] = ii; } } cout<<(1LL * p[n] * p[n] - dp[n][k]) / 2<<"\n"; vector<int> all; while (k > 0){ all.pb(pr[n][k]); n = all.back(); k--; } reverse(all.begin(), all.end()); for (int i: all) cout<<i<<" "; }
#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...