blob: 78a4db80e79c901f400bf16bc3bfdebe0456d16d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#include <stdlib.h>
#include "heap.h"
void heapify(int arr[], int n, int i)
{
if (i == 0)
return;
int parent = (i - 1) / 2;
if (parent >= 0)
{
if (arr[i] > arr[parent])
{
int tmp = arr[i];
arr[i] = arr[parent];
arr[parent] = tmp;
heapify(arr, n, parent);
}
}
}
void add(struct heap *heap, int val)
{
if (heap->size == heap->capacity)
{
heap->array = realloc(heap->array, heap->capacity * 2 * sizeof(int));
if (heap->array == NULL)
{
free(heap);
return;
}
heap->capacity *= 2;
}
heap->array[heap->size] = val;
heap->size++;
heapify(heap->array, heap->size, heap->size - 1);
}
|