python基本算法之实现归并排序(Merge sort)


Posted in Python onSeptember 01, 2020

0、前言

评判一个算法的好坏的标准:

  • 时间复杂度
  • 空间复杂度

1、归并排序算法是什么?

冒泡排序(Bubble Sort)是一种建立在归并操作上面的一种有效的排序算法,由John von neumann于1945年发明。采用分治法(Divide and Conquer)的经典应用!!将规模较大的排序问题化归到较小的规模上解决。

基本实现包含下面的两种方法:

自上而下的递归
自下而上的迭代

将已经有的有序子序列合并,得到完全有序的子序列。就是先得到每个子序列有序,然后在使得两个子序列合并成为一个有序的。如果是把两个有序表合并成为一个有序表,成为二路归并。

归并排序的性能不受到输入数据的影响,这一个和选择排序是一样的,但是性能比选择排序要好,性能始终是O(n log n)。但是性能的优越必定是额外的内存空间作为巨大代价的!

2、算法过程图解

python基本算法之实现归并排序(Merge sort)

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,0
 merge_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 += 1
  else:
   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_list

if __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)内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python文件及目录操作实例详解
Jun 04 Python
python创建列表并给列表赋初始值的方法
Jul 28 Python
python实现词法分析器
Jan 31 Python
Python实战购物车项目的实现参考
Feb 20 Python
django重新生成数据库中的某张表方法
Aug 28 Python
python实现根据文件格式分类
Oct 31 Python
flask框架配置mysql数据库操作详解
Nov 29 Python
Python遍历字典方式就实例详解
Dec 28 Python
PyQt5 界面显示无响应的实现
Mar 26 Python
python json.dumps中文乱码问题解决
Apr 01 Python
通过Django Admin+HttpRunner1.5.6实现简易接口测试平台
Nov 11 Python
Python测试框架pytest高阶用法全面详解
Jun 01 Python
在pycharm中文件取消用 pytest模式打开的操作
Sep 01 #Python
Python内置函数property()如何使用
Sep 01 #Python
mac安装python3后使用pip和pip3的区别说明
Sep 01 #Python
python3.7.3版本和django2.2.3版本是否可以兼容
Sep 01 #Python
解决python便携版无法直接运行py文件的问题
Sep 01 #Python
django有哪些好处和优点
Sep 01 #Python
python实现简单的五子棋游戏
Sep 01 #Python
You might like
php5编程中的异常处理详细方法介绍
2008/07/29 PHP
PHP中is_file不能替代file_exists的理由
2014/03/04 PHP
基于OpenCart 开发支付宝,财付通,微信支付参数错误问题
2015/10/01 PHP
PHP常见字符串处理函数用法示例【转换,转义,截取,比较,查找,反转,切割】
2016/12/24 PHP
ThinkPHP实现图片上传操作的方法详解
2017/05/08 PHP
jQuery使用手册之二 DOM操作
2007/03/24 Javascript
jQuery 1.5.1 发布,全面支持IE9 修复大量bug
2011/02/26 Javascript
JS小功能(checkbox实现全选和全取消)实例代码
2013/11/28 Javascript
JavaScript window.location对象
2014/11/14 Javascript
js实现遮罩层弹出框的方法
2015/01/15 Javascript
jQuery中DOM树操作之使用反向插入方法实例分析
2015/01/23 Javascript
nodejs实现获取当前url地址及url各种参数值
2015/06/25 NodeJs
JavaScript之Vue.js【入门基础】
2016/12/06 Javascript
vue.js实现请求数据的方法示例
2017/02/07 Javascript
jQuery html表格排序插件tablesorter使用方法详解
2017/02/10 Javascript
nvm、nrm、npm 安装和使用详解(小结)
2019/01/17 Javascript
Vue中对iframe实现keep alive无刷新的方法
2019/07/23 Javascript
vue 实现把路由单独分离出来
2020/08/13 Javascript
vue中使用echarts的示例
2021/01/03 Vue.js
用Python脚本生成Android SALT扰码的方法
2013/09/18 Python
Python实现批量下载文件
2015/05/17 Python
剖析Python的Tornado框架中session支持的实现代码
2015/08/21 Python
Swift 3.0在集合类数据结构上的一些新变化总结
2016/07/11 Python
Python探索之自定义实现线程池
2017/10/27 Python
Python使用matplotlib绘制三维图形示例
2018/08/25 Python
Python实现使用request模块下载图片demo示例
2019/05/24 Python
Python语言进阶知识点总结
2019/05/28 Python
python PIL/cv2/base64相互转换实例
2020/01/09 Python
Python的pygame安装教程详解
2020/02/10 Python
Python使用pycharm导入pymysql教程
2020/09/16 Python
彪马俄罗斯官网:PUMA俄罗斯
2019/07/13 全球购物
乡镇纠风工作实施方案
2014/03/22 职场文书
2015年教师工作总结范文
2015/03/31 职场文书
工会文体活动总结
2015/05/07 职场文书
通知怎么写?
2019/04/17 职场文书
Python之Matplotlib绘制热力图和面积图
2022/04/13 Python