summaryrefslogtreecommitdiff
path: root/heap-sort.py
blob: c8a45ebfd0bc81fd5bd98677160cd6c844dc4221 (plain)
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
#!/bin/python3

# ---------- Heap Sort Algorithm
# 


# ---------- Imported modules
import inputoutput as io
import csv
import sys


# ---------- Main
target = sys.argv[1]

# ingress of data
numdata = io.ingressCSV(target)


# Heap function (set up for algorithm)
def heapMake(data, node, root):
    
    # create root and define left and right tree branches
    maxi = root
    left = 2 * root + 1
    rite = 2 * root + 2

    # check for existence of left child and if so, compare to root
    if left < node and data[maxi] < data[left]:
        maxi = left

    # check for existence of right child and if so, compare to root
    if rite < node and data[maxi] < data[rite]:
        maxi = rite

    # if needed change out root value using a swap assignment
    if maxi != root:
        data[root], data[maxi] = data[maxi], data[root]

        # recursively make root into a heap
        heapMake(data, node, maxi)


# Algorithm
def heapSort(atad):
    span = len(atad)

    # buildup heap
    for i in range(span // 2 - 1, -1, -1):
        heapMake(atad, span, i)

    # extract heap elements single-file
    for i in range(span - 1, 0, -1):
        # swap assignment
        atad[i], atad[0] = atad[0], atad[i]
        heapMake(atad, i, 0)

# using sorting algorithm
heapSort(numdata)

# finishing up
print("Sorting done! Writing to file")
io.egressCSV(numdata,target)