#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 double *x, double *ans_out) {
  double ans_double = 0.0;

  double K = 0.25 * (double)n;
  int n1 = n + 1;
  double *P = (double *)malloc((size_t)n1 * sizeof(double));
  int *dq = (int *)malloc((size_t)n1 * sizeof(int));
  if (!P || !dq) {
    if (P)
      free(P);
    if (dq)
      free(dq);
    *ans_out = 0.0;
    return;
  }
  P[0] = 0.0;
  for (int i = 0; i < n; i++) {
    P[i + 1] = P[i] + x[i];
  }
  int head = 0;
  int tail = 0;
  int best = n + 1;
  for (int i = 0; i < n1; i++) {
    while (head < tail && (P[i] - P[dq[head]]) >= K) {
      int cand = i - dq[head];
      if (cand < best)
        best = cand;
      head++;
    }
    while (head < tail && P[i] <= P[dq[tail - 1]]) {
      tail--;
    }
    dq[tail++] = i;
  }
  if (best == n + 1)
    best = -1;
  ans_double = (double)best;
  free(P);
  free(dq);

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(T003_Code_005, SSUBGEK, 4096, 16384, 65536,
                   double *x = malloc((size_t)n * sizeof(double));
                   double ans_scalar = 0.0;, bench_fill_array_pos(x, n, seed);
                   , kernel_run(n, x, &ans_scalar), ans_scalar, free(x);)
