# | 제출 시각UTC-0 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
7610 | hongjun7 | 수열 (APIO14_sequence) | C++98 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std;
#define MK 202
#define MN 100002
int N, K, i, j, k, X[MN], _k = 1, best[MK][MN], s[MN], b;
long long d[2][MN], f[MN], S[MN];
bool ok(int z) {
int x = s[b-1], y = s[b];
return (f[y]-f[x])*(S[y]-S[z]) >= (f[z]-f[y]) *(S[x]-S[y]);
}
int main() {
int x;
scanf("%d%d",&N,&K);
for (i = 1; i <= N; i++) {
scanf("%d", &X[i]);
S[i] = S[i-1] + X[i];
}
for (i = 0; i <= N; i++) d[0][i] = -1;
for (k = 2; k <= K+1; k++) {
_k = k&1;
for (i = 0; i <= N; i++) d[_k][i] = 0;
b = -1; x = 1;
s[++b] = 0; s[++b] = 1;
for (i = 0; i <= N; i++) f[i] = d[!(_k)][i]-S[i]*S[i];
for (i = 2; i <= N; i++) {
if (x > b) x = b;
while (x < b && (f[s[x]]-f[s[x+1]]) <= (S[s[x+1]] - S[s[x]])*S[i]) x++;
d[_k][i] = f[s[x]]+S[s[x]]*S[i];