#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) {
  double ans_double = 0.0;
  const int REQUIRED = 5;

  int need[26];
  int have[26];
  for (int i = 0; i < 26; i++) {
    need[i] = 0;
    have[i] = 0;
  }
  for (int c = 0; c < REQUIRED; c++) {
    need[c] = 1;
  }
  int formed = 0;
  int left = 0;
  int best_len = n + 1;
  for (int right = 0; right < n; right++) {
    int idx = (int)(s[right] - 'a');
    if (idx < 0)
      idx = 0;
    if (idx > 25)
      idx = 25;
    have[idx]++;
    if (need[idx] > 0 && have[idx] == need[idx]) {
      formed++;
    }
    while (formed == REQUIRED && left <= right) {
      int winlen = right - left + 1;
      if (winlen < best_len)
        best_len = winlen;
      int idx2 = (int)(s[left] - 'a');
      if (idx2 < 0)
        idx2 = 0;
      if (idx2 > 25)
        idx2 = 25;
      have[idx2]--;
      if (need[idx2] > 0 && have[idx2] < need[idx2]) {
        formed--;
      }
      left++;
    }
  }
  if (best_len == n + 1)
    best_len = 0;
  ans_double = (double)best_len;

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_004, MINWIN, 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);)
