python基本算法之实现归并排序(Merge sort)
0、前言
评判一个算法的好坏的标准:
- 时间复杂度
- 空间复杂度
1、归并排序算法是什么?
冒泡排序(BubbleSort)是一种建立在归并操作上面的一种有效的排序算法,由Johnvonneumann于1945年发明。采用分治法(DivideandConquer)的经典应用!!将规模较大的排序问题化归到较小的规模上解决。
基本实现包含下面的两种方法:
自上而下的递归
自下而上的迭代
将已经有的有序子序列合并,得到完全有序的子序列。就是先得到每个子序列有序,然后在使得两个子序列合并成为一个有序的。如果是把两个有序表合并成为一个有序表,成为二路归并。
归并排序的性能不受到输入数据的影响,这一个和选择排序是一样的,但是性能比选择排序要好,性能始终是O(nlogn)。但是性能的优越必定是额外的内存空间作为巨大代价的!
2、算法过程图解
3、代码实现
代码如下(示例01):
""" Merge_Sort归并排序 分治算法DivideandConquer 时间复杂度: """ #切割数组的函数 defmerge_sort(alist): #如果长度小于等于1,不能再分割了 iflen(alist)<=1: returnalist #根据列表长度确定拆分的中间位置 mid_index=len(alist)//2 #使用切片实现对列表的切分 #left_list=alist[:mid_index] #right_list=alist[mid_index:] #递归调用,无限切割下去 left_list=merge_sort(alist[:mid_index]) right_list=merge_sort(alist[mid_index:]) returnmerge(left_list,right_list) #排序的函数 defmerge(left_list,right_list): l_index,r_index=0,0 merge_list=[] #判断列表里面是否还有元素可以用 whilel_index里面的左右列表都是被划分到了只有一个元素的是去比较和添加的。大家可以把代码放置到编译器里面,debug运行,看一哈具体的过程,结合动态图片演示理解更好!
4、评判算法
- 最好时间复杂度:O(nlogn)
- 最坏时间复杂度:O(nlogn)
- 平均时间复杂度:O(nlogn)
- 空间复杂度:O(n)
- 算法稳定性:稳定的排序
总结
到此这篇关于python基本算法之实现归并排序(Mergesort)的文章就介绍到这了,更多相关python归并排序(Mergesort)内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。