aboutsummaryrefslogtreecommitdiff
path: root/tests/core/test_bsearch.in
blob: 3b5fb6bcb1602e70546940a890f1285a7384b65b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <stdlib.h>
#include <stdio.h>

int cmp(const void* key, const void* member) {
  return *(int*)key - *(int*)member;
}

void printResult(int* needle, int* haystack, unsigned int len) {
  void* result = bsearch(needle, haystack, len, sizeof(unsigned int), cmp);

  if (result == NULL) {
    printf("null\n");
  } else {
    printf("%d\n", *(unsigned int*)result);
  }
}

int main() {
  int a[] = {-2, -1, 0, 6, 7, 9};
  int b[] = {0, 1};

  /* Find all keys that exist. */
  for (int i = 0; i < 6; i++) {
    int val = a[i];

    printResult(&val, a, 6);
  }

  /* Keys that are covered by the range of the array but aren't in
   * the array cannot be found.
   */
  int v1 = 3;
  int v2 = 8;
  printResult(&v1, a, 6);
  printResult(&v2, a, 6);

  /* Keys outside the range of the array cannot be found. */
  int v3 = -1;
  int v4 = 2;

  printResult(&v3, b, 2);
  printResult(&v4, b, 2);

  return 0;
}