-
Notifications
You must be signed in to change notification settings - Fork 96
/
Copy pathheapSort.cpp
63 lines (44 loc) · 1.47 KB
/
heapSort.cpp
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#include<iostream>
using namespace std;
#define Child(i, pos) 2*i+pos
void Max_Heapify(int Heap[], int i, int Len){
int Left_Child = Child(i, 1); //1 to indicate Left Child
int Right_Child = Child(i, 2); //2 to indicate Right Child
int temp, Largest = i;
//Find the largest element among the Root, Left child and Right child
if(Left_Child < Len and Heap[Left_Child] > Heap[i]) Largest = Left_Child;
if(Right_Child < Len and Heap[Right_Child] > Heap[Largest]) Largest = Right_Child;
//if root is not the largest, Swap root with largest and Heapify again
if(Largest != i){
temp = Heap[Largest];
Heap[Largest] = Heap[i];
Heap[i] = temp;
Max_Heapify(Heap, Largest, Len);
}
}
void Build_Max_Heap(int Heap[], int N){
for(int i=(N/2)-1; i>=0; i--)
Max_Heapify(Heap, i, N);
}
void Print(int Heap[], int N){
for(int i=0; i<N; i++) cout<<Heap[i] <<", ";
}
void Heap_Sort(int Heap[], int N){
int temp;
Build_Max_Heap(Heap, N); //Build Heap
for(int i=0; i<N; i++){
temp = Heap[0]; //Swap Root Of Heap with the last element
Heap[0] = Heap[N-i-1];
Heap[N-i-1] = temp;
Max_Heapify(Heap, 0, N-i-1); //Heapify again from root, reduce length to ignore the last (sorted) elements in array
}
}
int main(){
int Heap[] = {13,-3,-25,20,-3,-16,-23,18,20,-7,12,-5,-22,15,-4,7}, N=16;
cout<<"Orignal array = ";
Print(Heap, N); //Print Orignal Array
Heap_Sort(Heap, N); //Heap Sort
cout<<"\n Sorted array = ";
Print(Heap, N); //Print Sorted Array
cout<<endl;
}