导语:
本文主要介绍了关于python归并排序的基本思路的相关知识,希望可以帮到处于编程学习途中的小伙伴
基本思路
归纳排序是采用分治法的非常典型的应用。
1.先把拆开的组归还,再合并组。基本思想是将数组分解为最小尺寸,然后合并两个排序的数组。
2、基本思路是比较两个数组最前面的数,取小的先取,取完后移动对应的指针。
然后比较直到一组为空,最后复制另一组的剩余部分。
实例
# 归并排序
def merge_sort(alist):
'''归并排序'''
n = len(alist)
if n <= 1:
return alist
else:
mid = n // 2
# left 表示采用归并排序后形成的有序的新的列表
left_li = merge_sort(alist[:mid])
# right 表示采用归并排序后形成的有序的新的列表
right_li = merge_sort(alist[mid:])
# 将两个有序的子序列合并成一个新的整体
# merge(left,right)
left_pointer,right_pointer = 0,0
result = []
while left_pointer < len(left_li) and right_pointer < len(right_li):
if left_li[left_pointer] <= right_li[right_pointer]:
result.append(left_li[left_pointer])
left_pointer += 1
else:
result.append(right_li[right_pointer])
right_pointer += 1
result += left_li[left_pointer:]
result += right_li[right_pointer:]
return result
if __name__ == '__main__':
alist = [54, 26, 93, 17, 77, 31, 44, 55, 20]
print(alist)
sorted_alist = merge_sort(alist)
print(sorted_alist)
本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python的列表有顺序吗?09/01
- ♥ Python 如何使用 Spacy 进行分词10/18
- ♥ 什么是 python 归并排序12/06
- ♥ 如何检查python环境是否安装正确09/29
- ♥ linux下python运行失败怎么办11/23
- ♥ python集合中添加新元素的方法有哪些?11/19
内容反馈