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使用PyCrypto实现AES加密功能示例
May 22 Python
Python最火、R极具潜力 2017机器学习调查报告
Dec 11 Python
python爬虫爬取网页表格数据
Mar 07 Python
Appium Python自动化测试之环境搭建的步骤
Jan 23 Python
浅析python的Lambda表达式
Feb 27 Python
基于python实现自动化办公学习笔记(CSV、word、Excel、PPT)
Aug 06 Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
Jun 12 Python
解决python3.6用cx_Oracle库连接Oracle的问题
Dec 07 Python
python用700行代码实现http客户端
Jan 14 Python
Python开发之QT解决无边框界面拖动卡屏问题(附带源码)
May 27 Python
Python实现socket库网络通信套接字
Jun 04 Python
OpenCV-Python实现轮廓的特征值
Jun 09 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 ob_flush,flush在ie中缓冲无效的解决方法
2010/05/09 PHP
浅析php学习的路线图
2013/07/10 PHP
摘自百度的图片轮换效果代码
2007/11/19 Javascript
javascript作用域容易记错的两个地方分析
2012/06/22 Javascript
JavaScript面向对象知识串结(读JavaScript高级程序设计(第三版))
2012/07/17 Javascript
js解析json读取List中的实体对象示例
2014/03/11 Javascript
JavaScript设计模式之单件模式介绍
2014/12/28 Javascript
浅析JS运动
2015/12/28 Javascript
JS实现动态生成表格并提交表格数据向后端
2020/11/25 Javascript
Vue.JS入门教程之事件监听
2016/12/01 Javascript
jQuery简介_动力节点Java学院整理
2017/07/04 jQuery
json2.js 入门教程之使用方法与实例分析
2017/09/14 Javascript
Vue $emit $refs子父组件间方法的调用实例
2018/09/12 Javascript
微信小程序实现手势滑动卡片效果
2019/08/26 Javascript
[01:02:46]VGJ.S vs NB 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
[52:06]FNATIC vs NIP 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/19 DOTA
[01:02:26]DOTA2-DPC中国联赛 正赛 SAG vs RNG BO3 第二场 1月18日
2021/03/11 DOTA
python3.7.0的安装步骤
2018/08/27 Python
对python Tkinter Text的用法详解
2018/10/11 Python
如何爬取通过ajax加载数据的网站
2019/08/15 Python
Pytorch实现的手写数字mnist识别功能完整示例
2019/12/13 Python
Python2和Python3中@abstractmethod使用方法
2020/02/04 Python
python3发送request请求及查看返回结果实例
2020/04/30 Python
python中JWT用户认证的实现
2020/05/18 Python
Django rest framework分页接口实现原理解析
2020/08/21 Python
学习Python需要哪些工具
2020/09/04 Python
Python爬虫如何破解JS加密的Cookie
2020/11/19 Python
解决canvas转base64/jpeg时透明区域变成黑色背景的方法
2016/10/23 HTML / CSS
canvas实现扭蛋机动画效果的示例代码
2018/10/17 HTML / CSS
美国最大的农村生活方式零售店:Tractor Supply Company(TSC)
2017/05/15 全球购物
国际经济与贸易专业大学生职业规划书
2014/03/01 职场文书
机电一体化求职信
2014/03/10 职场文书
驾驶员安全责任书范本
2014/07/24 职场文书
环境保护建议书
2014/08/26 职场文书
党员领导干部民主生活会批评与自我批评发言
2014/09/28 职场文书
2015入党自传格式范文
2015/06/26 职场文书