#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 int *a, double *ans_out) {
  double ans_double = 0.0;

  int cnt[10000];
  int *arr = (int *)malloc((size_t)n * sizeof(int));
  if (!arr)
    return;
  for (int ci = 0; ci < 10000; ci++)
    cnt[ci] = 0;
  for (int i = 0; i < n; i++) {
    int v = a[i] % 10000;
    if (v < 0)
      v = 0;
    cnt[v]++;
  }
  int idx = 0;
  int mn = -1;
  int mx = -1;
  for (int v = 0; v < 10000; v++) {
    int c = cnt[v];
    if (c) {
      if (mn < 0)
        mn = v;
      mx = v;
      for (int t = 0; t < c; t++) {
        arr[idx++] = v;
      }
    }
  }
  int k = n;
  int low = 0;
  int high = (mn >= 0 && mx >= mn) ? (mx - mn) : 0;
  while (low < high) {
    int mid = (low + high) / 2;
    long long count_pairs = 0;
    int j = 0;
    for (int i = 0; i < n; i++) {
      while (j < n && (arr[j] - arr[i]) <= mid) {
        j++;
      }
      count_pairs += (long long)(j - i - 1);
    }
    if (count_pairs >= (long long)k) {
      high = mid;
    } else {
      low = mid + 1;
    }
  }
  ans_double = (double)low;
  free(arr);

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_002, KTHPAIR, 4096, 16384, 65536,
    int *a = (int *)malloc((size_t)n * sizeof(int));
    double ans_scalar = 0.0;,
                            {
                              bench_rng64_t rng = bench_rng_init(seed);
                              for (int i = 0; i < n; i++) {
                                a[i] = (int)(bench_rng_next(&rng) % 10000ULL);
                              }
                            },
                            kernel_run(n, a, &ans_scalar), ans_scalar, free(a);)
