acl/lib_acl/samples/btree/main.c

57 lines
1.1 KiB
C
Raw Normal View History

2014-11-19 00:25:21 +08:00
#include "lib_acl.h"
#include <stdlib.h>
#include <stdio.h>
int main(void)
{
ACL_BTREE *b;
unsigned int i, *x;
unsigned int v[] = {15, 5, 16, 3, 12, 20, 10, 13, 18, 23, 6, 7};
unsigned int nv = sizeof(v) / sizeof(v[0]);
b = acl_btree_create();
for(i = 0; i < nv; i++) {
x = (unsigned int*) acl_mymalloc(sizeof(unsigned int));
*x = (unsigned int) i;
if (acl_btree_add(b, v[i], (void*) x) != 0) {
printf("Fail Add %u %u\r\n", v[i], *x);
}
}
printf("depth %d\n", acl_btree_depth(b));
acl_btree_dump(b);
sleep(3);
x = acl_btree_remove(b, 5);
if (x)
acl_myfree(x);
acl_btree_dump(b);
sleep(3);
x = acl_btree_remove(b, 16);
if (x)
acl_myfree(x);
acl_btree_dump(b);
sleep(3);
x = acl_btree_remove(b, 13);
if (x)
acl_myfree(x);
acl_btree_dump(b);
while (acl_btree_get_min_key(b, &i) == 0) {
if ((x = acl_btree_remove(b, i)) == NULL) {
fprintf(stderr, "Failed to remove %u\r\n", i);
} else
acl_myfree(x);
acl_btree_dump(b);
sleep(1);
}
if (acl_btree_destroy(b) == -1) {
printf("Failed to destroy \r\n");
}
return (0);
}