#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 unsigned char *s, double *y) {
  int *d1 = (int *)malloc((size_t)n * sizeof(int));
  int *d2 = (int *)malloc((size_t)n * sizeof(int));
  if (!d1 || !d2) {
    if (d1)
      free(d1);
    if (d2)
      free(d2);
    y[0] = 0.0;
    y[1] = 0.0;
    return;
  }
  double last_total = 0.0;
  double last_best = 0.0;

  long long total_pal = 0;
  int best_len = 0;
  {
    int l = 0, r = -1;
    for (int i = 0; i < n; i++) {
      int k = 1;
      if (i <= r) {
        int mir = l + r - i;
        int val = d1[mir];
        int avail = r - i + 1;
        k = (val < avail) ? val : avail;
      }
      while (i - k >= 0 && i + k < n && s[i - k] == s[i + k])
        k++;
      d1[i] = k;
      int cand_len = 2 * k - 1;
      if (cand_len > best_len)
        best_len = cand_len;
      total_pal += (long long)k;
      if (i + k - 1 > r) {
        l = i - k + 1;
        r = i + k - 1;
      }
    }
  }
  {
    int l = 0, r = -1;
    for (int i = 0; i < n; i++) {
      int k = 0;
      if (i <= r) {
        int mir = l + r - i + 1;
        int val = d2[mir];
        int avail = r - i + 1;
        k = (val < avail) ? val : avail;
      }
      while (i - k - 1 >= 0 && i + k < n && s[i - k - 1] == s[i + k])
        k++;
      d2[i] = k;
      int cand_len = 2 * k;
      if (cand_len > best_len)
        best_len = cand_len;
      total_pal += (long long)k;
      if (i + k - 1 > r) {
        l = i - k;
        r = i + k - 1;
      }
    }
  }
  last_total = (double)total_pal;
  last_best = (double)best_len;

  y[0] = last_total;
  y[1] = last_best;
  free(d1);
  free(d2);
}
BENCH_MAIN_ARRAY3_D(
    T003_Code_010, MANACHER, 4096, 16384, 65536,
    unsigned char *s = (unsigned char *)malloc((size_t)n *
                                               sizeof(unsigned char));
    double *y = (double *)malloc(2 * sizeof(double));
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        s[i] = (unsigned char)('a' + (bench_rng_next(&rng) % 26ULL));
      }
    },
    kernel_run(n, s, y), y, 2, free(s);
    free(y);)
