|
Comprehensive C Archive Network |
|---|
| Upload Code | Download Code | About |
| Browse Source | Download (without any required ccan dependencies) |
Module:asearch |
Summary:typesafe binary search (bsearch) |
Author:Rusty Russell <rusty@rustcorp.com.au> |
Dependencies:ccan/typesafe_cb ccan/array_size |
Description:An ordered array of objects can be efficiently searched using a binary search algorithm; the time taken is around log(number of elements). This version uses macros to be typesafe on platforms which support it. |
Example:#include <ccan/asearch/asearch.h>
#include <stdio.h>
#include <string.h>
static int cmp(const char *key, char *const *elem)
{
return strcmp(key, *elem);
}
int main(int argc, char *argv[])
{
char **p;
if (argc < 2) {
fprintf(stderr, "Usage: %s <key> <list>...\n"
"Print position of key in (sorted) list\n",
argv[0]);
exit(1);
}
p = asearch(argv[1], &argv[2], argc-2, cmp);
if (!p) {
printf("Not found!\n");
return 1;
}
printf("%u\n", (int)(p - &argv[2]));
return 0;
}
|
License:LGPL |