제출 #335362

#제출 시각아이디문제언어결과실행 시간메모리
335362vkgainz수열 (APIO14_sequence)C++17
0 / 100
31 ms6220 KiB
#include <bits/stdc++.h> using namespace std; using ll = long long; ll s[100001]; ll dp[201][100001]; int par[201][100001]; double slope(int p, int x, int y) { // x > y return (double) (dp[p-1][y] - dp[p-1][x] - s[y] * s[y] + s[x] * s[x]) / (s[x] - s[y]); } int main() { int n, k; cin >> n >> k; s[0] = 0; for(int i = 1; i <= n; i++) { cin >> s[i]; s[i] += s[i-1]; } dp[0][0] = -1e15; par[0][0] = -1; for(int i=1;i<=n;i++) { dp[0][i] = 0; par[0][i] = -1; } for(int p=1;p<=k;p++) { deque<int> q; dp[p][0] = -1e15; q.push_back(0); for(int i=1;i<=n;i++) { bool found = false; if(i<=p) { dp[p][i] = -1e15; par[p][i] = -1; found = true; } while(q.size()>1 && slope(p, q[0], q[1])<s[i]) q.pop_front(); int j = q.front(); if(!found) { dp[p][i] = dp[p-1][j]+(s[i]-s[j])*1LL*s[j]; par[p][i] = j; } while(q.size()>1&&slope(p, q[q.size()-1], q[q.size()-2])>slope(p, q[q.size()-1], i)) q.pop_back(); q.push_back(i); } } vector<int> ans; int curr =n; for(int p=k;p>=1;p--) { ans.push_back(par[p][curr]); curr = par[p][curr]; } cout << dp[k][n] << "\n"; for(auto &a : ans) cout << a << " "; }
#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...