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解析xml文件实例分析
May 27 Python
基于wxpython实现的windows GUI程序实例
May 30 Python
利用Python爬取可用的代理IP
Aug 18 Python
python爬虫入门教程--HTML文本的解析库BeautifulSoup(四)
May 25 Python
Python编程之序列操作实例详解
Jul 22 Python
Python3计算三角形的面积代码
Dec 18 Python
Python爬虫通过替换http request header来欺骗浏览器实现登录功能
Jan 07 Python
Python实现的直接插入排序算法示例
Apr 29 Python
python使用opencv驱动摄像头的方法
Aug 03 Python
python梯度下降法的简单示例
Aug 31 Python
简述 Python 的类和对象
Aug 21 Python
Python __slots__的使用方法
Nov 15 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 读取大文件的X行到Y行内容的实现代码
2013/06/24 PHP
PHP提示Deprecated: mysql_connect(): The mysql extension is deprecated的解决方法
2014/08/28 PHP
php示例详解Constructor Prototype Pattern 原型模式
2015/10/15 PHP
thinkphp5框架实现的自定义扩展类操作示例
2019/05/16 PHP
Laravel 微信小程序后端实现用户登录的示例代码
2019/11/26 PHP
一步一步教你写一个jQuery的插件教程(Plugin)
2009/09/03 Javascript
Jquery EasyUI中弹出确认对话框以及加载效果示例代码
2014/02/13 Javascript
初识Node.js
2014/09/03 Javascript
javascript实现动态表头及表列的展现方法
2015/07/14 Javascript
jQuery手机拨号界面特效代码分享
2015/08/27 Javascript
在 Node.js 中使用原生 ES 模块方法解析
2017/09/19 Javascript
使用vue实现简单键盘的示例(支持移动端和pc端)
2017/12/25 Javascript
Vue下路由History模式打包后页面空白的解决方法
2018/06/29 Javascript
对angularJs中$sce服务安全显示html文本的实例
2018/09/30 Javascript
详解vue项目中使用token的身份验证的简单实践
2019/03/08 Javascript
微信小程序授权登录解决方案的代码实例(含未通过授权解决方案)
2019/05/10 Javascript
js前端如何写一个精确的倒计时代码
2019/10/25 Javascript
Vue使用预渲染代替SSR的方法
2020/07/02 Javascript
Python发送Email方法实例
2014/08/21 Python
深入理解Python变量与常量
2016/06/02 Python
Python 编码处理-str与Unicode的区别
2016/09/06 Python
python3+PyQt5实现支持多线程的页面索引器应用程序
2018/04/20 Python
python读取文本绘制动态速度曲线
2018/06/21 Python
virtualenv 指定 python 解释器的版本方法
2018/10/25 Python
python使用xlrd模块读取xlsx文件中的ip方法
2019/01/11 Python
Python 3.8中实现functools.cached_property功能
2019/05/29 Python
pytorch逐元素比较tensor大小实例
2020/01/03 Python
Expedia法国:全球最大在线旅游公司
2018/09/30 全球购物
Java Servlet API中forward() 与redirect()的区别
2014/04/20 面试题
招聘与培训专员岗位职责
2014/01/30 职场文书
幼儿教师工作感言
2014/02/14 职场文书
纪律教育学习月活动总结
2014/08/27 职场文书
KTV门卫岗位职责
2014/10/09 职场文书
二年级语文上册复习计划
2015/01/19 职场文书
SpringBoot整合RabbitMQ的5种模式实战
2021/08/02 Java/Android
永中文档在线转换预览基于nginx配置部署方案
2022/06/10 Servers