归并排序是采用分治法的一个非常典型的应用。归并排序的思想就是先递归分解数组,再合并数组。
将数组分解最小之后,然后合并两个有序数组,基本思路是比较两个数组的最前面的数,谁小就先取谁,取了后相应的指针就往后移一位。然后再比较,直至一个数组为空,最后把另一个数组的剩余部分复制过来即可。
# -*- coding:utf-8 -*-
#归并排序
def merge_sort(alist):
if len(alist) <= 1:
return alist
else:
mid = len(alist)//2
left_list = merge_sort(alist[:mid])
right_list = merge_sort(alist[mid:])
return merge(left_list, right_list)
def merge(left_list, right_list):
result = []
left_pointer = 0
right_pointer = 0
while left_pointer < len(left_list) and right_pointer < len(right_list):
if left_list[left_pointer] < right_list[right_pointer]:
result.append(left_list[left_pointer])
left_pointer += 1
elif left_list[left_pointer] >= right_list[right_pointer]:
result.append(right_list[right_pointer])
right_pointer += 1
result += (left_list[left_pointer:])
result += (right_list[right_pointer:])
return result
时间复杂度
- 最优时间复杂度:O(nlogn)
- 最坏时间复杂度:O(nlogn)
- 稳定性:稳定