归并排序
归并排序的思想就是先递归分解数组,再合并数组。
归并排序是采用分治法的一个非常经典的应用。
其基本思路是:
假设:有一个数组:list = [2,5,4,3],对其进行排序。
第一步:将数组以分治法划分。
第二步,
第二步步骤分解:
实现代码:
def merge(left, right):
'''合并操作,将两个有序数组left[]和right[]合并成一个大的有序数组'''
#left与right的下标指针
l, r = 0, 0
result = []
while l<len(left) and r<len(right):
if left[l] < right[r]:
result.append(left[l])
l += 1
else:
result.append(right[r])
r += 1
result += left[l:]#添加数组中剩余的元素,两个数组不一定相同,
result += right[r:]
return result
def mergesort(alist):
if len(alist) <= 1:
return alist
# 二分分解
num = len(alist)//2
left = mergesort(alist[:num])#递归调用,二分法,直到分解到单个值,然后左右排序,
right = mergesort(alist[num:])
# 合并
return merge(left,right)
alist = [32,45,95,26,78,31,44,55,20]
sorted_alist = mergesort(alist)
print(sorted_alist)
[20, 26, 31, 32, 44, 45, 55, 78, 95]