#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void kernel_run(int n, const int *w, double *ans_out) {
  int m = n;
  if (m > 128)
    m = 128;
  if (m < 1)
    m = 1;
  long long *pref = (long long *)malloc((size_t)(m + 1) * sizeof(long long));
  long long *dpbuf =
      (long long *)malloc((size_t)m * (size_t)m * sizeof(long long));
  if (!pref || !dpbuf) {
    if (pref)
      free(pref);
    if (dpbuf)
      free(dpbuf);
    *ans_out = 0.0;
    return;
  }
  pref[0] = 0;
  for (int i = 0; i < m; i++) {
    pref[i + 1] = pref[i] + (long long)w[i];
  }
  for (int i = 0; i < m; i++) {
    dpbuf[i * m + i] = 0;
  }
  const long long INF = 0x3fffffffffffffffLL;
  for (int len = 2; len <= m; len++) {
    for (int i = 0; i + len - 1 < m; i++) {
      int j = i + len - 1;
      long long best = INF;
      long long s = pref[j + 1] - pref[i];
      for (int k = i; k < j; k++) {
        long long cand = dpbuf[i * m + k] + dpbuf[(k + 1) * m + j] + s;
        if (cand < best)
          best = cand;
      }
      dpbuf[i * m + j] = best;
    }
  }
  long long best_all = dpbuf[0 * m + (m - 1)];
  double ans_double = 0.0;
  double base_ans = (double)best_all;

  ans_double = base_ans;

  *ans_out = ans_double;
  free(pref);
  free(dpbuf);
}
BENCH_MAIN_SCALAR3(
    T003_Code_030, INTERVAL, 4096, 16384, 65536,
    int *w = (int *)malloc((size_t)n * sizeof(int));
    double ans_scalar = 0.0;,
                            {
                              bench_rng64_t rng = bench_rng_init(seed);
                              for (int i = 0; i < n; i++) {
                                w[i] =
                                    (int)(bench_rng_next(&rng) % 1000ULL) + 1;
                              }
                            },
                            kernel_run(n, w, &ans_scalar), ans_scalar, free(w);)
