#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
static inline double run_sssp(int n, const int *rowptr, const int *colind,
                              const int *w, int *dist, int *next_node,
                              int *bucket_head, int maxBuckets) {
  const int INF = 0x3f3f3f3f;

  for (int i = 0; i < n; i++) {
    dist[i] = INF;
    bucket_head[i] = 0; /* reuse as visited[i] = 0 */
  }
  dist[0] = 0;

  for (int step = 0; step < n; step++) {
    int u = -1;
    int best = INF;
    for (int v = 0; v < n; v++) {
      if (!bucket_head[v] && dist[v] < best) {
        best = dist[v];
        u = v;
      }
    }
    if (u == -1) {
      break;
    }
    bucket_head[u] = 1; /* mark visited */

    int a = rowptr[u];
    int c = rowptr[u + 1];
    for (int e = a; e < c; e++) {
      int v = colind[e];
      int nd = dist[u] + w[e];
      if (nd < dist[v]) {
        dist[v] = nd;
      }
    }
  }

  long long sumd = 0;
  for (int i = 0; i < n; i++) {
    if (dist[i] < INF) {
      sumd += (long long)dist[i];
    }
  }
  double ans = (double)sumd;

  double outv = 0.0;
  outv = ans;
  return outv;
}
BENCH_MAIN_SCALAR3(
    T004_Module_049, DELTA_SSSP, 16384, 32768, 65536, int KOUT = 4;
    int edges_cap = n * KOUT;
    int *rowptr = (int *)malloc((size_t)(n + 1) * sizeof(int));
    int *colind = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *w = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *dist = (int *)malloc((size_t)n * sizeof(int));
    int *next_node = (int *)malloc((size_t)n * sizeof(int));
    int maxBuckets = n * 16;
    int *bucket_head = (int *)malloc((size_t)maxBuckets * sizeof(int));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      int pos = 0;
      for (int u = 0; u < n; u++) {
        rowptr[u] = pos;
        for (int k = 0; k < KOUT; k++) {
          int v = (int)(bench_rng_next(&rng) % (unsigned long long)n);
          int ww = (int)(bench_rng_next(&rng) % 9ULL) + 1;
          colind[pos] = v;
          w[pos] = ww;
          pos++;
        }
      }
      rowptr[n] = pos;
    },
    ans_scalar = run_sssp(n, rowptr, colind, w, dist, next_node, bucket_head,
                          maxBuckets),
    ans_scalar, free(rowptr);
    free(colind); free(w); free(dist); free(next_node); free(bucket_head);)
