A heap is a binary tree (having hierarchal structure having parent and the child relationship) which satisfies the following heap ordering property stated below :

minheap property: value of each of the child in tree should have value greater than or equal to value of its parent, thereby having the minimumvalue always at the root.

maxheap property: value of each of the child in tree should have value smaller than or equal to value of its parent, thereby having the maximum value always at the root.
Heaps find their applications in Heap Sort, Priority Queue, various Graph Algorithms like Dijkstraâ€™s single source shortest Path and spanning tree algorithms like Primâ€™s Minimum Spanning Tree etc.
In a heap max/ min element is always at root depending upon the heap property it follows. There is no relationship between various nodes on any of the given level, or even among siblings. As heap is complete binary tree so its minimum height with N number of nodes is always having O(log N) height.
Adjusting the tree according to the heap ordering property is called heapify operation.
Heapify operation requires two approaches
 Top down approach: When heapify operation is made side by side in addition with insertion operation
 Bottom up approach: When heapify operation is applied to the last after inserting all the elements in the heap tree i.e first of all, tree is build and then the tree ordering property is checked to make it a heap
Insertion in heap
Each time whenever a new element is encountered it is initially added to end of heap (considering it as last element of array). The heapify operation is applied if heap ordering property is violated on addition of the new element.
Implementation :
void heapify(int c) //min heap { int p, tmp; if (c != 0) { p = getP(c); if (data[p] >data[c]) { tmp = data[p]; data[p] = data[c]; data[c] = tmp; heapify(p); } } } void insert(int val) { if ( heap_Size = = array_Size) throw string("Heap overflow"); else { heap_Size++; data[heap_Size  1] = val; heapify(heap_Size  1); } }
Deletion in heap
When element is deleted it is replaced to the element present at end of the heap . The heapify operation is applied if heap ordering property is violated by swapping of deleted element with last element .
Implementation:
void heapify (int c) //min heap { int lchild, rchild, minIndex, tmp; lchild = getLchild(c); rchild = getRchild(c); if (rchild >= heapSize) { if (lchild >= heapSize) return; else minIndex = lchild; } else { if (data[lchild] <= data[rchild]) minIndex = lchild; else minIndex = rchild; } if (data[c] > data[minIndex]) { tmp = data[minIndex]; data[minIndex] = data[c]; data[c] = tmp; heapify(minIndex); } } void del() { if (isEmpty()) throw string("Heap is empty"); else { data[0] = data[heapSize  1]; heapSize; if (heapSize > 0) heapify(0); } }
Complexity
Inserting new element in heap requires O(h) time, where h is height of heap. Considering completeness of heap as complete binary tree, O(h) = O(log n), where it is given that n is the number of the elements in the given heap. Deletion of element in the heap will require O(h) time = O(log n), where it is given that h is the height of heap and n is the number of elements which are present in given heap.
Sample Tutorial Problem
Rajiv went for an interview in a very big MNC company. While giving answers for interviewer questions, he stuck one a tricky question. Help him in solving this question. He is given an empty array B. Queries are of 4 types:
1:Y  Add number Y to the array B.
2:Y  Remove a single instance of number Y from the array B. If not possible, return 1.
3  Find the maximum element in the array B.
4  Find the minimum element in the array B.
Input Format
Input 1: It will be an string array where :
First line will tell the total number of rows Q
Next each consecutive Q lines will contain a query like the ones mentioned above.
Constraints
1 <=Q <= 100000
1 <= Y <= 100000
Output Format
For queries 3 and 4, return the answer in a string format separated by comma. If the array is empty for query 3 and 4, then return 1.
Sample TestCase 1
Input
5 1:5 1:9 1:6 3 2:1
Output
9,1