
#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, int V, int E, const int *eu, const int *ev,
                const unsigned char *ew, double *ans_out) {
  double ans_double = 0.0;

  int *head = (int *)malloc((size_t)V * sizeof(int));
  int *to = (int *)malloc((size_t)E * sizeof(int));
  int *wt = (int *)malloc((size_t)E * sizeof(int));
  int *nxt = (int *)malloc((size_t)E * sizeof(int));
  if (!head || !to || !wt || !nxt) {
    if (head)
      free(head);
    if (to)
      free(to);
    if (wt)
      free(wt);
    if (nxt)
      free(nxt);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < V; i++)
    head[i] = -1;
  for (int i = 0; i < E; i++) {
    int u = eu[i];
    int v = ev[i];
    if (u < 0)
      u = 0;
    if (u >= V)
      u %= V;
    if (v < 0)
      v = 0;
    if (v >= V)
      v %= V;
    to[i] = v;
    wt[i] = (int)(ew[i] & 1U);
    nxt[i] = head[u];
    head[u] = i;
  }
  int INF = 2147483647;
  int *dist = (int *)malloc((size_t)V * sizeof(int));
  if (!dist) {
    free(head);
    free(to);
    free(wt);
    free(nxt);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < V; i++)
    dist[i] = INF;
  dist[0] = 0;
  int deq_cap = V * 4 + 8;
  int *deq = (int *)malloc((size_t)deq_cap * sizeof(int));
  if (!deq) {
    free(dist);
    free(head);
    free(to);
    free(wt);
    free(nxt);
    *ans_out = 0.0;
    return;
  }
  int front = 0;
  int back = 1;
  deq[0] = 0;
  while (front != back) {
    int u = deq[front];
    front = (front + 1) % deq_cap;
    for (int e = head[u]; e != -1; e = nxt[e]) {
      int v = to[e];
      int w = wt[e];
      int nd = dist[u] + w;
      if (nd < dist[v]) {
        dist[v] = nd;
        if (w == 0) {
          front = (front - 1 + deq_cap) % deq_cap;
          deq[front] = v;
        } else {
          deq[back] = v;
          back = (back + 1) % deq_cap;
        }
      }
    }
  }
  int tnode = V - 1;
  if (tnode < 0)
    tnode = 0;
  ans_double = (double)dist[tnode];
  free(deq);
  free(dist);
  free(head);
  free(to);
  free(wt);
  free(nxt);

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_021, ZOBFS, 4096, 16384, 65536, int V = n / 512 + 4;
    if (V > 256) V = 256; int base_chain = (V > 1 ? (V - 1) : 0);
    int extraE = V * 3; int E = base_chain + extraE;
    int *eu = (int *)malloc((size_t)E * sizeof(int));
    int *ev = (int *)malloc((size_t)E * sizeof(int));
    unsigned char *ew = (unsigned char *)malloc((size_t)E *
                                                sizeof(unsigned char));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      int idx = 0;
      for (int i = 0; i < V - 1 && idx < E; i++) {
        eu[idx] = i;
        ev[idx] = i + 1;
        ew[idx] = (unsigned char)(bench_rng_next(&rng) & 1ULL);
        idx++;
      }
      while (idx < E) {
        int u = (int)(bench_rng_next(&rng) % (uint64_t)V);
        int v = (int)(bench_rng_next(&rng) % (uint64_t)V);
        if (u == v)
          v = (v + 1) % V;
        eu[idx] = u;
        ev[idx] = v;
        ew[idx] = (unsigned char)(bench_rng_next(&rng) & 1ULL);
        idx++;
      }
    },
    kernel_run(n, V, E, eu, ev, ew, &ans_scalar), ans_scalar, free(eu);
    free(ev); free(ew);)
