Sergi Vladykin 2fa40dd436
Zig CC cross-compilation support for Windows on Linux host. (#128)
Zig CC cross-compilation support for Windows on Linux host
2023-12-21 10:50:39 +03:00
..
2022-02-05 00:11:52 +03:00
2022-08-20 18:56:21 +03:00
2022-02-05 00:11:52 +03:00
2022-12-30 23:04:00 +03:00

Heap

Overview

  • Min-heap implementation, it can be used as Max-heap/priority queue as well.

Usage


#include "sc_heap.h"

#include <stdio.h>


int main(int argc, char *argv[])
{
	struct data {
		int priority;
		char *data;
	};

	struct data n[] = {{1, "first"},
			   {4, "fourth"},
			   {5, "fifth"},
			   {3, "third"},
			   {2, "second"}};

	struct sc_heap_data *elem;
	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 ((elem = sc_heap_pop(&heap)) != NULL) {
		printf("key = %d, data = %s \n", 
                    (int) elem->key, (char*) elem->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 ((elem = sc_heap_pop(&heap)) != NULL) {
		printf("key = %d, data = %s \n", 
                    (int) elem->key, (char*) elem->data);
	}

	sc_heap_term(&heap);

	return 0;
}