#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
typedef struct {
  int page;
  int last1;
  int last2;
  int valid;
} Frame2;
static inline int find_frame(Frame2 *f, int cap, int page) {
  for (int i = 0; i < cap; i++) {
    if (f[i].valid && f[i].page == page)
      return i;
  }
  return -1;
}
static inline int choose_victim(Frame2 *f, int cap) {
  for (int i = 0; i < cap; i++) {
    if (!f[i].valid)
      return i;
  }
  int best = 0;
  int best_score = f[0].last2;
  for (int i = 1; i < cap; i++) {
    if (f[i].last2 < best_score) {
      best = i;
      best_score = f[i].last2;
    }
  }
  return best;
}
static double lru2_run(int n, const int *reqs) {
  int cap = n / 32;
  if (cap < 4)
    cap = 4;
  if (cap > 256)
    cap = 256;
  Frame2 *tab = (Frame2 *)malloc((size_t)cap * sizeof(Frame2));
  if (!tab)
    return 0.0;
  memset(tab, 0, (size_t)cap * sizeof(Frame2));
  long long hits = 0;
  for (int t = 1; t <= n; t++) {
    int p = reqs[t - 1];
    int idx = find_frame(tab, cap, p);
    if (idx >= 0) {
      hits++;
      tab[idx].last2 = tab[idx].last1;
      tab[idx].last1 = t;
    } else {
      int v = choose_victim(tab, cap);
      tab[v].page = p;
      tab[v].last2 = 0;
      tab[v].last1 = t;
      tab[v].valid = 1;
    }
  }
  free(tab);
  double ans_once = (double)hits;
  double ans = 0.0;

  ans = ans_once;
  return ans;
}
BENCH_MAIN_SCALAR3(
    T004_Module_056, LRUK, 4096, 16384, 65536,
    int *reqs = (int *)malloc((size_t)n * sizeof(int));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      int hotN = 32;
      int allN = 256;
      for (int i = 0; i < n; i++) {
        if ((bench_rng_next(&rng) & 3ULL) != 0) {
          reqs[i] = (int)(bench_rng_next(&rng) % (unsigned long long)hotN);
        } else {
          reqs[i] = (int)(bench_rng_next(&rng) % (unsigned long long)allN);
        }
      }
    },
    ans_scalar = lru2_run(n, reqs), ans_scalar, free(reqs);)
