#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 *ans_out) {
  int *Z = (int *)malloc((size_t)n * sizeof(int));
  int *mark = (int *)malloc((size_t)(n + 1) * sizeof(int));
  if (!Z || !mark) {
    if (Z)
      free(Z);
    if (mark)
      free(mark);
    *ans_out = 0.0;
    return;
  }
  double ans_double = 0.0;

  memset(mark, 0, (size_t)(n + 1) * sizeof(int));
  if (n > 0)
    Z[0] = n;
  int L = 0, R = 0;
  for (int i = 1; i < n; i++) {
    int z = 0;
    if (i <= R) {
      int bound = R - i + 1;
      int v = Z[i - L];
      z = (v < bound) ? v : bound;
    }
    while ((i + z) < n && s[z] == s[i + z])
      z++;
    Z[i] = z;
    if (i + z - 1 > R) {
      L = i;
      R = i + z - 1;
    }
  }
  for (int i = 1; i < n; i++) {
    int zi = Z[i];
    if (zi > 0 && i + zi == n && zi < n) {
      mark[zi] = 1;
    }
  }
  int borders = 0;
  for (int len = 1; len < n; len++) {
    if (mark[len])
      borders++;
  }
  ans_double = (double)borders;

  *ans_out = ans_double;
  free(Z);
  free(mark);
}
BENCH_MAIN_SCALAR3(
    T003_Code_014, ZALGO, 4096, 16384, 65536,
    unsigned char *s = (unsigned char *)malloc((size_t)n *
                                               sizeof(unsigned char));
    double ans_scalar = 0.0;
    ,
    {
      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, &ans_scalar), ans_scalar, free(s);)
