Init commit, initial version of c heap-sort for generic types
This commit is contained in:
34
c/test.c
Normal file
34
c/test.c
Normal file
@@ -0,0 +1,34 @@
|
||||
#include <stdio.h>
|
||||
|
||||
#include "data_structures/heap.h"
|
||||
#include "algorithms/sort_heap.h"
|
||||
|
||||
int compare_nodes(dlos_ComparableNode *a, dlos_ComparableNode *b) {
|
||||
int left = *((int*) a->value);
|
||||
int right = *((int*) b->value);
|
||||
if (left > right) {
|
||||
return -1;
|
||||
} else if (left == right) {
|
||||
return 0;
|
||||
} else {
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
int test_size = 10;
|
||||
int data_storage[] = {73, 6, 57, 88, 60, 42, 83, 72, 48, 85};
|
||||
dlos_ComparableNode a[test_size];
|
||||
for (int i = 0; i < test_size; i++) {
|
||||
a[i].value = &data_storage[i];
|
||||
}
|
||||
dlos_Heap heap = { .size = test_size, .arr = a, .compare = compare_nodes };
|
||||
dlos_max_heap(&heap);
|
||||
dlos_sort_heap(&heap);
|
||||
for (int i = 0; i < test_size; i++) {
|
||||
if (i == 0) printf("sorted: ");
|
||||
printf("%d, ", *((int*) heap.arr[i].value));
|
||||
if (i == test_size - 1) printf("\n");
|
||||
}
|
||||
return 0;
|
||||
}
|
Reference in New Issue
Block a user