제출 #989911

#제출 시각아이디문제언어결과실행 시간메모리
989911awf수열 (APIO14_sequence)C++14
49 / 100
61 ms131072 KiB
#include<bits/stdc++.h> using namespace std; const int N = 1e5 + 15; #define int long long int a[N]; int b[N]; int n, k; int dp[N][2]; int pre[N]; int nm; int w[N]; int x[N]; int tv[N][205]; int id = 0; int cost(int l, int r){ return (pre[r] - pre[l-1]) * (pre[n] - pre[r]); } void cal(int k, int l, int r, int opl, int opr) { if (l > r) return; int mid = (l + r) / 2; int opm = -1; dp[mid][1] = 0; for (int i = opr; i >= opl; i--) { int val = dp[i][0] + cost(i+1,mid); if (val > dp[mid][1]) { dp[mid][1] = val; opm = i; } } tv[mid][id] = opm; // cout << mid << " " << id << " " << opm << endl; cal(k, l, mid - 1, opl, opm); cal(k, mid + 1, r, opm, opr); } signed main() { ios_base::sync_with_stdio(); cin.tie(0); cin >> n >> k; for (int i = 1; i <= n; i++) cin >> a[i]; for (int i = 1; i <= n; i++) { pre[i] = pre[i-1] + a[i]; } for (int i = 1; i <= n; i++) dp[i][0] = cost(1,i); for (int i = 2; i <= k; i++) { id++; cal(i, 1, n, 1, n); for (int j = 1; j <= n; j++) { dp[j][0] = dp[j][1]; dp[j][1] = 0; } } // for(int i=2; i<=k; i++){ // for(int j=1; j<=n; j++){ // cout << dp[j][i] << endl; // } // cout << endl; // } int mx = 0; int last = 0; for(int i=1; i<=n; i++){ if(mx < dp[i][0]){ last = i; mx = dp[i][0]; } } cout << mx << endl; for(int i=k-1; i>=0; i--){ cout << last << " "; last = tv[last][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...