In computer science, a heap is a specialized tree-based data structure that satisfies the heap property: If A is a parent node of B then the key of node A is ordered with respect to the key of node B with the same ordering applying across the heap. A heap can be classified further as either a "max heap" or a "min heap". In a max heap, the keys of parent nodes are always greater than or equal to those of the children and the highest key is in the root node. In a min heap, the keys of parent nodes are less than or equal to those of the children and the lowest key is in the root node. Heaps are crucial in several efficient graph algorithms such as Dijkstra's algorithm, and in the sorting algorithm heapsort. A common implementation of a heap is the binary heap, in which the tree is a complete binary tree (see figure).
In a heap, the highest (or lowest) priority element is always stored at the root, hence the name heap. A heap is not a sorted structure and can be regarded as partially ordered. As visible from the heap-diagram, there is no particular relationship among nodes on any given level, even among the siblings. When a heap is a complete binary tree, it has a smallest possible height—a heap with N nodes always has log N height. A heap is a useful data structure when you need to remove the object with the highest (or lowest) priority.
1: package com.examples.ajay;
2: class Heap{
3: int[] array;
4: int count;
5: int capacity;
6: int heap_type;
7: }
8: public class HeapImplementation {
9: public static Heap createHeap(int capacity, int heap_type){
10: Heap heap = new Heap();
11: heap.array = new int[capacity];
12: if(heap.array == null) return null;
13: heap.heap_type = heap_type;
14: heap.count = 0;
15: heap.capacity = capacity;
16: return heap;
17: }
18: public static int getParent(Heap heap, int i){
19: if(i >= heap.count || i <= 0) return -1; //asking for parent of root or entry outside the amount of elements in heap
20: return (i-1)/2;
21: }
22: public static int leftChild(Heap heap, int i){
23: int left = 2*i + 1;
24: if(left >= heap.count) return -1;
25: else return left;
26: }
27: public static int rightChild(Heap heap, int i){
28: int right = 2*i + 2;
29: if(right >= heap.count) return -1;
30: else return right;
31: }
32: public static int getMaximum(Heap heap){
33: if(heap.count <= 0) return -1;
34: else return heap.array[0];
35: }
36: public static void heapify(Heap heap , int i){
37: int left, right, max;
38: left = leftChild(heap, i);
39: right = rightChild(heap, i);
40: //exchange parent with the maximum among both of left or right children
41: if(left != -1 && heap.array[left] > heap.array[i]) max = left;
42: else max = i;
43: if(right != -1 && heap.array[right] > heap.array[max]) max = right;
44: if(max != i){
45: int temp = heap.array[max];
46: heap.array[max] = heap.array[i];
47: heap.array[i] = temp;
48: heapify(heap, max);
49: }
50: }
51: public static int deleteMax(Heap heap){
52: int data;
53: if(heap.count <= 0) return -1;
54: data = heap.array[0];
55: heap.array[0] = heap.array[heap.count - 1];
56: heap.count--;
57: heapify(heap, 0);
58: return data;
59: }
60: public static void insert(Heap heap, int data){
61: if(heap.count == heap.capacity) resizeHeap(heap);
62: heap.count++;
63: int i = heap.count - 1;
64: //find location till data is greater than the parent of node which is inserted at count-1
65: while(i > 0 && data > heap.array[(i-1)/2]){
66: heap.array[i] = heap.array[(i-1)/2];
67: i = (i-1)/2;
68: }
69: heap.array[i] = data;
70: }
71: private static void resizeHeap(Heap heap) {
72: // TODO Auto-generated method stub
73: int i = 0;
74: int[] temp = heap.array;
75: heap.array = new int[heap.capacity * 2];
76: for (int element : temp) {
77: heap.array[i++] = element;
78: }
79: heap.capacity *= 2;
80: }
81: public static void main(String[] args) {
82: // TODO Auto-generated method stub
83: int[] heapArray = {3, 1, 9, 8, 14, 12, 5, 7, 31, 10, 16};
84: Heap heap = createHeap(heapArray.length, 0);
85: /*for(int element : heapArray){
86: insert(heap, element);
87: }*/
88: int i = 0;
89: for(int element : heapArray){
90: heap.array[i++] = element;
91: }
92: heap.count = heapArray.length;
93: for(i = (heapArray.length - 1)/2; i >= 0 ; i--) heapify(heap, i);
94: System.out.println("Results: ");
95: for(i = 0; i < heap.count ; i++){
96: System.out.print(heap.array[i] + " ");
97: }
98: System.out.println();
99: System.out.println("Deleing root ...");
100: deleteMax(heap);
101: System.out.println("Results: ");
102: for(i = 0; i < heap.count ; i++){
103: System.out.print(heap.array[i] + " ");
104: }
105: }
106: }
Output :
Results:
31 16 12 9 14 3 5 1 7 8 10
Deleting root ...
Results:
16 14 12 9 10 3 5 1 7 8