-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathmerge_sort.py
53 lines (40 loc) · 1005 Bytes
/
merge_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
"""
Merge Sort
Time Complexity: O(n log n)
"""
def combine(arr, LEFT_SUB, RIGHT_SUB):
i = j = k = 0
while i < len(LEFT_SUB) and j < len(RIGHT_SUB):
if LEFT_SUB[i] < RIGHT_SUB[j]:
arr[k] = LEFT_SUB[i]
i += 1
else:
arr[k] = RIGHT_SUB[j]
j += 1
k += 1
while i < len(LEFT_SUB):
arr[k] = LEFT_SUB[i]
i += 1
k += 1
while j < len(RIGHT_SUB):
arr[k] = RIGHT_SUB[j]
j += 1
k += 1
return arr
def merge_sort(arr):
if len(arr) < 2:
return
# devide whole list into 2 halves at point mid
mid = len(arr) // 2
LEFT_SUB = arr[:mid]
RIGHT_SUB = arr[mid:]
# sort two halves
merge_sort(LEFT_SUB)
merge_sort(RIGHT_SUB)
# combine two halves
return combine(arr, LEFT_SUB, RIGHT_SUB)
if __name__ == '__main__':
arr = [5, 1, 423, 12, -1, -1231, 9, 0]
print('before: ', arr)
merge_sort(arr)
print('after: ', arr)