제출 #975637

#제출 시각아이디문제언어결과실행 시간메모리
975637dosts수열 (APIO14_sequence)C++17
49 / 100
336 ms131072 KiB
//Dost SEFEROĞLU #pragma GCC optimize("O3,unroll-loops,Ofast") #include <bits/stdc++.h> using namespace std; #define int long long #define pii pair<int,int> #define ff first #define ss second #define sp << " " << #define vi vector<int> const int N = 1e5+1, K = 2e2+1,inf = 1e18; int dp[N][K]; bool Q; struct Line { mutable int a,b,p; bool operator < (const Line& o) const{ return Q ? p < o.p : a < o.a; }; }; struct CHT : multiset<Line> { int div(int a,int b) { return a/b - ((a^b) < 0 && a%b); } bool intersect(iterator x,iterator y) { if (y == end()) return x->p = inf,0; if (x->a == y->a) x->p = x->b <= y->b ? -inf : inf; else x->p = div(y->b-x->b,x->a-y->a); return x->p >= y->p; } void add(int a,int b) { auto z = insert({a,b,0}),y = z++,x = y; while (intersect(y,z)) z = erase(z); if (x != begin() && intersect(--x,y)) intersect(x,y = erase(y)); while ((y = x) != begin() && (--x)->p >= y->p) intersect(x,erase(y)); } int query(int x) { Q = 1; auto it = *lower_bound({0,0,x}); Q = 0; return it.a*x+it.b; } }; void solve() { int n,k; cin >> n >> k; vi a(n+1),p(n+1,0); for (int i=1;i<=n;i++) cin >> a[i]; for (int i=1;i<=n;i++) p[i] = p[i-1]+a[i]; for (int j=1;j<=k;j++) { CHT cht; cht.add(0,0); for (int i=1;i<=n;i++) { dp[i][j] = cht.query(p[i]); cht.add(p[i],dp[i][j-1]-(p[i]*p[i])); } } cout << dp[n][k] << endl; vi cuts; int ptr = n,ptr2 = k; while (ptr2) { for (int j=n;j>=1;j--) { if (dp[j][ptr2-1]+(p[ptr]-p[j])*p[j] == dp[ptr][ptr2]) { cuts.push_back(j); ptr = j; ptr2--; break; } } } reverse(cuts.begin(),cuts.end()); for (auto it : cuts) cout << it << " "; cout << endl; } signed main() { ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0); #ifdef Dodi freopen("in.txt","r",stdin); freopen("out.txt","w",stdout); #endif int t = 1; //cin >> t; while (t --> 0) solve(); }
#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...