归并排序的主要思路是先将数组不断拆分,直到子数组不能拆分为止,然后对子数组进行排序、与另一个子数组合并形成新的数组,再次排序,直到合并为一个数组;
看下面这张图就可以很清晰明了
python实现:
def merge_sort(items, comp=lambda x, y: x <= y):
"""归并排序(分治法)"""
if len(items) < 2:
return items[:]
mid = len(items) // 2
"""使用递归的方式再次切分"""
left = merge_sort(items[:mid], comp)
right = merge_sort(items[mid:], comp)
return merge(left, right, comp)
def merge(items1, items2, comp):
"""合并(将两个有序的列表合并成一个有序的列表)"""
items = []
index1, index2 = 0, 0
"""将两个有序列表中数据有序放入合并的数组"""
while index1 < len(items1) and index2 < len(items2):
if comp(items1[index1], items2[index2]):
items.append(items1[index1])
index1 += 1
else:
items.append(items2[index2])
index2 += 1
"""将两个有序列表剩余部分直接拼接到合并数组中"""
items += items1[index1:]
items += items2[index2:]
return items