Inserting in a Heap
- Heap is stored in an array representation.
- Starting index is considered to be 1. Element at index 0 will be 0.
- For an element in index i, its left child will be at index 2i and right child will be at index 2i + 1.
- For elements at index > 2, its parent element will be at the floor value of index /2.
void insertMaxHeap(int h[], int data, int index) {
// Check if data is greater than parent
while (index > 1 && data > h[index/2]) {
h[index] = h[index/2];
index = index/2;
}
h[index] = data;
}
void insertMinHeap(int h[], int data, int index) {
// Check if data is lesser than parent
while (index > 1 && data < h[index/2]) {
h[index] = h[index/2];
index = index/2;
}
h[index] = data;
}
void createHeap(int h[], int size) {
for (int i = 2; i <= size; i++) {
insertMaxHeap(h, h[i], i);
}
}
// int h[5] = {0, 34, 12, 56, 4};
// Heap size is 4. Don't include first index.
// createHeap(h, 4);
Last modified 3yr ago