-
Notifications
You must be signed in to change notification settings - Fork 0
/
merge_sort.py
36 lines (29 loc) · 1.06 KB
/
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
def merge_sort(arr):
if len(arr) <= 1:
return arr
mid = len(arr) // 2
left_half = arr[:mid]
right_half = arr[mid:]
return merge(merge_sort(left_half), merge_sort(right_half))
# відповідає за сортування двох підмасивів
def merge(left, right):
merged = []
left_index = 0
right_index = 0
# Спочатку об'єднайте менші елементи
while left_index < len(left) and right_index < len(right):
if left[left_index] <= right[right_index]:
merged.append(left[left_index])
left_index += 1
else:
merged.append(right[right_index])
right_index += 1
# Якщо в лівій або правій половині залишилися елементи,
# додайте їх до результату
while left_index < len(left):
merged.append(left[left_index])
left_index += 1
while right_index < len(right):
merged.append(right[right_index])
right_index += 1
return merged