-
Notifications
You must be signed in to change notification settings - Fork 0
/
104-heap_sort.c
70 lines (66 loc) · 1.47 KB
/
104-heap_sort.c
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
64
65
66
67
68
69
70
#include "sort.h"
/**
* check_tree - swiftdown check
* @array: pointer to array
* @size: size of the pointer
* @size_init: original size of the array
* @i: index as a root of the tree
*
**/
void check_tree(int *array, size_t size_init, size_t size, size_t i)
{
int n, branch1, branch2;
size_t br1, br2;
br1 = i * 2 + 1;
br2 = br1 + 1;
branch1 = array[br1];
branch2 = array[br2];
if (((br1 < size) && (br2 < size) &&
(branch1 >= branch2 && branch1 > array[i]))
|| ((br1 == size - 1) && branch1 > array[i]))
{
n = array[i];
array[i] = branch1;
array[br1] = n;
print_array(array, size_init);
}
else if ((br1 < size) && (br2 < size) &&
(branch2 > branch1 && branch2 > array[i]))
{
n = array[i];
array[i] = branch2;
array[br2] = n;
print_array(array, size_init);
}
if (br1 < size - 1)
check_tree(array, size_init, size, br1);
if (br2 < size - 1)
check_tree(array, size_init, size, br2);
}
/**
* heap_sort - sorts an array of integers
* in ascending order using the Heap
* sort algorithm
* @array: pointer to array
* @size: size of the pointer
*
**/
void heap_sort(int *array, size_t size)
{
size_t i, size_init = size;
int n;
if (!array)
return;
for (i = 0; i < size / 2 ; i++)
{
check_tree(array, size_init, size, size / 2 - 1 - i);
}
for (i = 0; i < size_init - 1; i++)
{
n = array[0];
array[0] = array[size - 1 - i];
array[size - 1 - i] = n;
print_array(array, size_init);
check_tree(array, size_init, size - i - 1, 0);
}
}