
#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, double *ans_out) {
  if (n < 2)
    n = 2;
  int *parent = (int *)malloc((size_t)n * sizeof(int));
  int *sz = (int *)malloc((size_t)n * sizeof(int));
  if (!parent || !sz) {
    if (parent)
      free(parent);
    if (sz)
      free(sz);
    *ans_out = 0.0;
    return;
  }
  int OPS = 128;
  int *stk_ra = (int *)malloc((size_t)OPS * sizeof(int));
  int *stk_rb = (int *)malloc((size_t)OPS * sizeof(int));
  int *stk_sz = (int *)malloc((size_t)OPS * sizeof(int));
  if (!stk_ra || !stk_rb || !stk_sz) {
    if (stk_ra)
      free(stk_ra);
    if (stk_rb)
      free(stk_rb);
    if (stk_sz)
      free(stk_sz);
    free(parent);
    free(sz);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < n; i++) {
    parent[i] = i;
    sz[i] = 1;
  }
  int sp = 0;
  int comp = n;
  unsigned long long checksum = 0ULL;
  for (int t = 0; t < OPS; t++) {
    int a = (t * 17 + 3) % n;
    int b = (t * 23 + 5) % n;
    if ((t % 4) != 3) {
      int ra = a;
      while (parent[ra] != ra)
        ra = parent[ra];
      int rb = b;
      while (parent[rb] != rb)
        rb = parent[rb];
      if (ra == rb) {
        stk_ra[sp] = -1;
        stk_rb[sp] = -1;
        stk_sz[sp] = 0;
        sp++;
      } else {
        if (sz[ra] < sz[rb]) {
          int tmp = ra;
          ra = rb;
          rb = tmp;
        }
        stk_ra[sp] = ra;
        stk_rb[sp] = rb;
        stk_sz[sp] = sz[ra];
        sp++;
        parent[rb] = ra;
        sz[ra] += sz[rb];
        comp--;
      }
    } else {
      if (sp > 0) {
        sp--;
        if (stk_ra[sp] != -1) {
          int ra = stk_ra[sp];
          int rb = stk_rb[sp];
          int oldsz = stk_sz[sp];
          parent[rb] = rb;
          sz[ra] = oldsz;
          comp++;
        }
      }
    }
    checksum += (unsigned long long)comp;
  }
  double ans_double = 0.0;

  ans_double = (double)checksum;

  *ans_out = ans_double;
  free(parent);
  free(sz);
  free(stk_ra);
  free(stk_rb);
  free(stk_sz);
}
BENCH_MAIN_SCALAR3(T003_Code_051, DSURB, 4096, 16384, 65536,
                   double ans_scalar = 0.0;
                   , ;, kernel_run(n, &ans_scalar), ans_scalar, ;)
