4399游戏大全,哪家公司做推广优化好,基于推荐算法的网站开发,如何向百度提交站点收录信息0、前言评判一个算法的好坏的标准#xff1a;时间复杂度空间复杂度1、归并排序算法是什么#xff1f;冒泡排序(Bubble Sort)是一种建立在归并操作上面的一种有效的排序算法#xff0c;由John von neumann于1945年发明。采用分治法(Divide and Conquer)的经典应用#xff01…0、前言评判一个算法的好坏的标准时间复杂度空间复杂度1、归并排序算法是什么冒泡排序(Bubble Sort)是一种建立在归并操作上面的一种有效的排序算法由John von neumann于1945年发明。采用分治法(Divide and Conquer)的经典应用将规模较大的排序问题化归到较小的规模上解决。基本实现包含下面的两种方法自上而下的递归自下而上的迭代将已经有的有序子序列合并得到完全有序的子序列。就是先得到每个子序列有序然后在使得两个子序列合并成为一个有序的。如果是把两个有序表合并成为一个有序表成为二路归并。归并排序的性能不受到输入数据的影响这一个和选择排序是一样的但是性能比选择排序要好性能始终是O(n log n)。但是性能的优越必定是额外的内存空间作为巨大代价的2、算法过程图解3、代码实现代码如下(示例01)Merge_Sort 归并排序分治算法Divide and Conquer时间复杂度# 切割数组 的函数def merge_sort(alist):# 如果长度小于等于1 不能再分割了if len(alist) 1:return alist# 根据列表长度确定拆分的中间位置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:])return merge(left_list, right_list)# 排序的函数def merge(left_list, right_list):l_index,r_index 0,0merge_list []# 判断列表里面是否还有元素可以用while l_index len(left_list) and r_index len(right_list):# 哪边的元素小于另外一边的的元素就把哪边的元素加入进去对应的索引加一if left_list[l_index] right_list[r_index]:merge_list.append(left_list[l_index])l_index 1else:merge_list.append(right_list[r_index])r_index 1# 下面的这两个就是如果有一个列表全部添加了另外一个列表直接添加到merge_list里面了merge_list left_list[l_index:]merge_list right_list[r_index:]return merge_listif __name__ __main__:alist [54, 26, 93, 17, 77, 31, 44, 55, 20]print(f原列表的顺序{alist})alist merge_sort(alist)print(f选择排序之后的列表的顺序{alist})里面的左右列表都是被划分到了只有一个元素的是去比较和添加的。大家可以把代码放置到编译器里面debug运行看一哈具体的过程结合动态图片演示理解更好4、评判算法最好时间复杂度O(n log n)最坏时间复杂度O(n log n)平均时间复杂度O(n log n)空间复杂度O(n)算法稳定性稳定的排序总结到此这篇关于python基本算法之实现归并排序(Merge sort)的文章就介绍到这了,更多相关python归并排序(Merge sort)内容请搜索随便开发网以前的文章或继续浏览下面的相关文章希望大家以后多多支持随便开发网