利用python实现归并排序,实现起来比较简单
def _merge(a:list, b:list) -> list:
"""合并两个排好序的数组"""
c = []
while len(a)>0 and len(b)>0:
if a[0] < b[0]:
c.append(a[0])
a.remove(a[0])
else:
c.append(b[0])
b.remove(b[0])
if len(a) == 0:
c += b
else:
c += a
return c
def _merge_sort(nums:list) -> list:
"""分治过程"""
if len(nums) <= 1:
return nums
m = len(nums)//2
a = _merge_sort(nums[:m])
b = _merge_sort(nums[m:])
return _merge(a, b)
if __name__ == '__main__':
a = [5,4,9,10,3,2,1]
b = _merge_sort(a)
print(b)