-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathheapSortAlgorithm.py
More file actions
77 lines (57 loc) · 1.95 KB
/
Copy pathheapSortAlgorithm.py
File metadata and controls
77 lines (57 loc) · 1.95 KB
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
71
72
73
74
75
76
77
import time
import sortingUtils
from sortingUtils import wait
startTime = 0
def heapify(array, n, i, delay):
largest = i
l = 2 * i + 1
r = 2 * i + 2
sortingUtils.selectedIndices.clear()
sortingUtils.comparedIndices.clear()
sortingUtils.selectedIndices.append(largest)
if l < n and array[l] > array[largest]:
largest = l
sortingUtils.selectedIndices.append(largest)
if r < n and array[r] > array[largest]:
largest = r
sortingUtils.selectedIndices.append(largest)
sortingUtils.comparisons += 1
if largest != i:
sortingUtils.comparedIndices.append(i)
sortingUtils.swaps += 1
array[i], array[largest] = array[largest], array[i]
yield from heapify(array, n, largest, delay)
sortingUtils.sortTimeVisual = time.perf_counter() - startTime
yield
wait(delay)
def heapSort(array, delay):
global startTime
startTime = time.perf_counter()
n = len(array)
for i in range(n // 2 - 1, -1, -1):
yield from heapify(array, n, i, delay)
for i in range(n - 1, 0, -1):
array[0], array[i] = array[i], array[0]
sortingUtils.swaps += 1
yield from heapify(array, i, 0, delay)
def heapifyNoVisible(array, n, i):
largest = i
l = 2 * i + 1
r = 2 * i + 2
if l < n and array[l] > array[largest]:
largest = l
if r < n and array[r] > array[largest]:
largest = r
if largest != i:
array[i], array[largest] = array[largest], array[i]
heapifyNoVisible(array, n, largest)
def heapSortNoVisible(array):
startTime = time.perf_counter()
timeArray = array.copy()
n = len(timeArray)
for i in range(n // 2 - 1, -1, -1):
heapifyNoVisible(timeArray, n, i)
for i in range(n - 1, 0, -1):
timeArray[0], timeArray[i] = timeArray[i], timeArray[0]
heapifyNoVisible(timeArray, i, 0)
sortingUtils.sortTime = time.perf_counter() - startTime