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 相关文章推荐
Windows下Python2与Python3两个版本共存的方法详解
Feb 12 Python
Django如何实现内容缓存示例详解
Sep 24 Python
Python元组拆包和具名元组解析实例详解
Mar 26 Python
Python中的并发处理之asyncio包使用的详解
Apr 03 Python
python logging日志模块以及多进程日志详解
Apr 18 Python
python3的输入方式及多组输入方法
Oct 17 Python
Python中xml和json格式相互转换操作示例
Dec 05 Python
PyTorch搭建一维线性回归模型(二)
May 22 Python
pytorch中的自定义反向传播,求导实例
Jan 06 Python
利用python中的matplotlib打印混淆矩阵实例
Jun 16 Python
解决python和pycharm安装gmpy2 出现ERROR的问题
Aug 28 Python
PyCharm+Miniconda3安装配置教程详解
Feb 16 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读取javascript设置的cookies的代码
2010/04/12 PHP
IIS6.0 开启Gzip方法及PHP Gzip函数分享
2014/06/08 PHP
再谈PHP中单双引号的区别详解
2016/06/12 PHP
PHP isset()及empty()用法区别详解
2020/08/29 PHP
JQuery autocomplete 使用手册
2010/04/01 Javascript
jQuery新闻滚动插件 jquery.roller.js
2011/06/27 Javascript
js关闭模态窗口刷新父页面或跳转页面
2012/12/13 Javascript
js动态往表格的td中添加图片并注册事件
2014/06/12 Javascript
jquery访问ashx文件示例代码
2014/08/11 Javascript
jquery获取radio值(单选组radio)
2014/10/16 Javascript
JavaScript 浏览器对象模型BOM使用介绍
2015/04/13 Javascript
jquery.mousewheel实现整屏翻屏效果
2015/08/30 Javascript
谈谈Jquery中的children find 的区别有哪些
2015/10/19 Javascript
JS获取地址栏参数的两种方法(简单实用)
2016/06/14 Javascript
jQuery的Each比JS原生for循环性能慢很多的原因
2016/07/05 Javascript
简单的JS轮播图代码
2016/07/18 Javascript
详解js中Json的语法与格式
2016/11/22 Javascript
QRCode.js:基于JQuery的生成二维码JS库的使用
2017/06/23 jQuery
JS实现分页浏览横向图片(类轮播)实例代码
2017/11/06 Javascript
webpack引入eslint配置详解
2018/01/22 Javascript
JS中数据结构之栈
2019/01/01 Javascript
详解Vue.js中引入图片路径的几种方式
2019/06/17 Javascript
[30:51]DOTA2上海特级锦标赛主赛事日 - 3 胜者组第二轮#1Liquid VS MVP.Phx第一局
2016/03/04 DOTA
[34:08]2018DOTA2亚洲邀请赛3月29日 小组赛B组 VP VS EG
2018/03/30 DOTA
django允许外部访问的实例讲解
2018/05/14 Python
python lxml中etree的简单应用
2019/05/10 Python
python实现井字棋小游戏
2020/03/04 Python
Python抓包并解析json爬虫的完整实例代码
2020/11/03 Python
详解HTML5中ol标签的用法
2015/09/08 HTML / CSS
一个基于canvas的移动端图片编辑器的实现
2020/10/28 HTML / CSS
校园报刊亭创业计划书
2014/01/02 职场文书
银行职员工作失误检讨书
2014/10/14 职场文书
财产保全担保书
2015/01/20 职场文书
2019员工保密协议书(3篇)
2019/09/23 职场文书
Mysql事务索引知识汇总
2022/03/17 MySQL
古见同学有交流障碍症 第二季宣传CM公开播出
2022/04/11 日漫