제출 #402946

#제출 시각아이디문제언어결과실행 시간메모리
402946radaiosm7Split the sequence (APIO14_sequence)C++98
0 / 100
1905 ms34012 KiB
#include <bits/stdc++.h>
using namespace std;
int n, k, i, par;
long long pref[100005];
pair<long long, int> dp[100005][21];

void com(int l, int r, int optl, int optr) {
  if (l > r) return;

  int mid = (l+r) >> 1;

  if (i > mid-1) {
    dp[mid][i].first = LONG_LONG_MIN>>1LL;
  }

  pair<long long, int> ans = make_pair(0LL, -1);

  for (int j = optl; j <= min(mid-1, optr); ++j) {
    ans = max(ans, make_pair(dp[j][i-1].first + pref[j]*(pref[mid]-pref[j]), j));
  }

  dp[mid][i] = ans;

  com(l, mid-1, optl, ans.second);
  com(mid+1, r, ans.second, optr);
}

int main() {
  scanf("%d%d", &n, &k);
  pref[0] = 0LL;

  k = min(k, n-1);
  for (i=1; i <= n; ++i) {
    scanf("%lld", &pref[i]);
    pref[i] += pref[i-1];
  }

  for (i=1; i <= n; ++i) {
    dp[i][0].first = 0LL;
  }

  for (i=1; i <= k; ++i) {
    com(1, n, 1, n);
  }

  printf("%lld\n", dp[n][k]);

  par = n;
  for (i=k; i > 0; --i) {
    printf("%d%c", dp[par][i].second, (i==1)?('\n'):(' '));
    par = dp[par][i].second;
  }
  return 0;
}

컴파일 시 표준 에러 (stderr) 메시지

sequence.cpp: In function 'int main()':
sequence.cpp:46:14: warning: format '%lld' expects argument of type 'long long int', but argument 2 has type 'std::pair<long long int, int>' [-Wformat=]
   46 |   printf("%lld\n", dp[n][k]);
      |           ~~~^     ~~~~~~~~
      |              |            |
      |              |            std::pair<long long int, int>
      |              long long int
sequence.cpp:29:8: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   29 |   scanf("%d%d", &n, &k);
      |   ~~~~~^~~~~~~~~~~~~~~~
sequence.cpp:34:10: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   34 |     scanf("%lld", &pref[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...