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 的 with 语句详解
Jun 13 Python
Python程序设计入门(2)变量类型简介
Jun 16 Python
仅用500行Python代码实现一个英文解析器的教程
Apr 02 Python
Python3中常用的处理时间和实现定时任务的方法的介绍
Apr 07 Python
Windows安装Python、pip、easy_install的方法
Mar 05 Python
python如何使用正则表达式的前向、后向搜索及前向搜索否定模式详解
Nov 08 Python
python获取命令行输入参数列表的实例代码
Jun 23 Python
python+Django+pycharm+mysql 搭建首个web项目详解
Nov 29 Python
python 实现dict转json并保存文件
Dec 05 Python
关于Keras模型可视化教程及关键问题的解决
Jan 24 Python
python pptx复制指定页的ppt教程
Feb 14 Python
Python turtle编写简单的球类小游戏
Mar 31 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
php入门学习知识点一 PHP与MYSql连接与查询
2011/07/14 PHP
PHP把JPEG图片转换成Progressive JPEG的方法
2014/06/30 PHP
php通过排列组合实现1到9数字相加都等于20的方法
2015/08/03 PHP
WordPres对前端页面调试时的两个PHP函数使用小技巧
2015/12/22 PHP
PHP实现的线索二叉树及二叉树遍历方法详解
2016/04/25 PHP
PHP实现的多维数组排序算法分析
2018/02/10 PHP
javascript indexOf函数使用说明
2008/07/03 Javascript
javascript 学习之旅 (2)
2009/02/05 Javascript
关于javascript中的parseInt使用技巧
2009/09/03 Javascript
Jquery iframe内部出滚动条
2010/02/11 Javascript
JS验证控制输入中英文字节长度(input、textarea等)具体实例
2013/06/21 Javascript
jQuery插件multiScroll实现全屏鼠标滚动切换页面特效
2015/04/12 Javascript
JS实现仿QQ面板的手风琴效果折叠菜单代码
2015/09/11 Javascript
AngularJS  $on、$emit和$broadcast的使用
2016/09/05 Javascript
vue.js模仿京东省市区三级联动的选择组件实例代码
2017/11/22 Javascript
微信小程序ajax实现请求服务器数据及模版遍历数据功能示例
2017/12/15 Javascript
JavaScript图片旋转效果实现方法详解
2020/06/28 Javascript
[07:59]2014DOTA2叨叨刀塔 林熊猫称被邀请赛现场盛况震撼
2014/07/21 DOTA
Python爬虫爬取一个网页上的图片地址实例代码
2018/01/16 Python
python 每天如何定时启动爬虫任务(实现方法分享)
2018/05/21 Python
numpy 对矩阵中Nan的处理:采用平均值的方法
2018/10/30 Python
PyCharm的设置方法和第一个Python程序的建立
2019/01/16 Python
python输出数组中指定元素的所有索引示例
2019/12/06 Python
python实现按关键字筛选日志文件
2019/12/24 Python
Python imutils 填充图片周边为黑色的实现
2020/01/19 Python
浅谈matplotlib中FigureCanvasXAgg的用法
2020/06/16 Python
Python如何实现大型数组运算(使用NumPy)
2020/07/24 Python
CSS3实现文本垂直排列的方法
2018/07/10 HTML / CSS
深入浅析HTML5中的article和section的区别
2018/05/15 HTML / CSS
html5 制作地图当前定位箭头的方法示例
2020/01/10 HTML / CSS
食品安全汇报材料
2014/08/18 职场文书
黄石寨导游词
2015/02/05 职场文书
2015年体检中心工作总结
2015/05/27 职场文书
病假条格式范文
2015/08/17 职场文书
Vue+Element UI实现概要小弹窗的全过程
2021/05/30 Vue.js
vscode中使用npm安装babel的方法
2021/08/02 Javascript