mirror of
https://github.com/tezc/sc.git
synced 2025-01-14 06:43:04 +08:00
c221478638
* Switched to tabs for indentation, amalgamation tool works with tabs only
51 lines
873 B
C
51 lines
873 B
C
#include "sc_heap.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
int main()
|
|
{
|
|
struct data {
|
|
int priority;
|
|
char *data;
|
|
};
|
|
|
|
struct data n[] = {{1, "first"},
|
|
{4, "fourth"},
|
|
{5, "fifth"},
|
|
{3, "third"},
|
|
{2, "second"}};
|
|
|
|
int64_t key;
|
|
void *data;
|
|
struct sc_heap heap;
|
|
|
|
sc_heap_init(&heap, 0);
|
|
|
|
// Min-heap usage
|
|
for (int i = 0; i < 5; i++) {
|
|
sc_heap_add(&heap, n[i].priority, n[i].data);
|
|
}
|
|
|
|
while (sc_heap_pop(&heap, &key, &data)) {
|
|
printf("key = %ld, data = %s \n", (long int) key,
|
|
(char *) data);
|
|
}
|
|
printf("---------------- \n");
|
|
|
|
/**
|
|
* Max-heap usage, negate when adding into heap
|
|
* and negate back after pop :
|
|
*/
|
|
|
|
for (int i = 0; i < 5; i++) {
|
|
sc_heap_add(&heap, -(n[i].priority), n[i].data);
|
|
}
|
|
|
|
while (sc_heap_pop(&heap, &key, &data)) {
|
|
printf("key = %ld, data = %s \n", (long int) -key,
|
|
(char *) data);
|
|
}
|
|
|
|
return 0;
|
|
}
|