导语:
本文主要介绍了关于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中输入多个变量08/31
- ♥ python判断是否为小数09/21
- ♥ 如何在 Python 中从 numpy 数组中添加和删除元素08/11
- ♥ python请求检测响应状态码09/12
- ♥ 学Python有钱途吗02/28
- ♥ python3 os中创建文件夹的方法有哪些?10/24
内容反馈