forked from kelvins/algorithms-and-data-structures
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinsertion_sort.py
63 lines (50 loc) · 1.52 KB
/
insertion_sort.py
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
""" Insertion Sort in Python (Iterative and Recursive) """
def insertion_sort_iterative(vector):
"""
Implementation of insertion sort iteratively.
Arguments:
vector (list): list to be sorted.
Returns:
Returns the sorted list.
"""
for i in range(1, len(vector)):
key = vector[i]
aux = i - 1
while aux >= 0 and vector[aux] > key:
vector[aux + 1] = vector[aux]
aux -= 1
vector[aux + 1] = key
return vector
def insertion_sort_recursive(vector, index):
"""
Implementation of insertion sort recursively.
Arguments:
vector (list): list to be sorted.
index (int): index of the element to be sorted in the list.
Returns:
Returns the sorted list.
"""
aux = index
while vector[aux] < vector[aux - 1]:
temp = vector[aux]
vector[aux] = vector[aux - 1]
vector[aux - 1] = temp
aux -= 1
if aux == 0:
break
if index < len(vector) - 1:
insertion_sort_recursive(vector, index + 1)
return vector
if __name__ == "__main__":
list1 = [8, 1, 3, 5, 7, 9, 0, 2, 4, 6]
print("Unsorted list: ")
print(list1)
list1 = insertion_sort_iterative(list1)
print("Sorted list with iterative insertion sort: ")
print(list1)
list2 = [8, 1, 3, 5, 7, 9, 0, 2, 4, 6]
print("Unsorted list: ")
print(list2)
list2 = insertion_sort_recursive(list2, 1)
print("Sorted list with recursive insertion sort: ")
print(list2)