Skip to content

Commit 6d34c5b

Browse files
committed
Add heap sort
1 parent 8e446af commit 6d34c5b

File tree

1 file changed

+63
-0
lines changed

1 file changed

+63
-0
lines changed

Basic/Sort/heapsort.cpp

+63
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,63 @@
1+
/*
2+
* heapsort.cpp
3+
* Copyright (C) 2019 Guowei Chen <[email protected]>
4+
*
5+
* Distributed under terms of the MIT license.
6+
*/
7+
8+
9+
#include <iostream>
10+
11+
void swap (int &a, int &b) {
12+
int tmp = a;
13+
a = b;
14+
b = tmp;
15+
}
16+
17+
// NOTO: insert i into max heap.
18+
void heapify(int * arr, int n, int i) {
19+
int largest = i;
20+
int l = 2 * i + 1, r = 2 * i + 2;
21+
22+
if (l < n && arr[l] > arr[largest]) {
23+
largest = l;
24+
}
25+
26+
if (r < n && arr[r] > arr[largest]) {
27+
largest = r;
28+
}
29+
30+
if (i != largest) {
31+
swap(arr[i], arr[largest]);
32+
heapify(arr, n, largest);
33+
}
34+
}
35+
36+
void build_max_heap(int * arr, int n) {
37+
for (int i = n / 2 - 1; i >= 0; --i) {
38+
heapify(arr, n, i);
39+
}
40+
}
41+
42+
void heapsort(int * arr, int n) {
43+
build_max_heap(arr, n);
44+
45+
for (int i = n - 1; i >= 0; --i) {
46+
swap(arr[0], arr[i]);
47+
heapify(arr, i, 0);
48+
}
49+
}
50+
51+
int main()
52+
{
53+
int arr[] = { 10, 20, 15, 17, 9, 21 };
54+
int n = 6;
55+
56+
heapsort(arr, n);
57+
58+
for (int i = 0; i < n; ++i) {
59+
std::cout << arr[i] << "\n";
60+
}
61+
62+
return 0;
63+
}

0 commit comments

Comments
 (0)