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下的subprocess模块的入门指引
Apr 16 Python
python实现的正则表达式功能入门教程【经典】
Jun 05 Python
Python实现动态图解析、合成与倒放
Jan 18 Python
Python3随机漫步生成数据并绘制
Aug 27 Python
对python中的argv和argc使用详解
Dec 15 Python
python实现AES加密与解密
Mar 28 Python
使用IDLE的Python shell窗口实例详解
Nov 19 Python
Python常用模块os.path之文件及路径操作方法
Dec 03 Python
Python : turtle色彩控制实例详解
Jan 19 Python
Python爬虫回测股票的实例讲解
Jan 22 Python
python热力图实现简单方法
Jan 29 Python
Django对接elasticsearch实现全文检索的示例代码
Aug 02 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
三国漫画《火凤燎原》宣布动画化PV放出 预计2020年播出
2020/03/08 国漫
利用discuz自带通行证整合dedecms的方法以及文件下载
2007/03/06 PHP
php获取远程图片并下载保存到本地的方法分析
2016/10/08 PHP
PHP获取对象属性的三种方法实例分析
2019/01/03 PHP
Laravel5.7 Eloquent ORM快速入门详解
2019/04/12 PHP
javascript delete 使用示例代码
2010/03/29 Javascript
javascript判断是否按回车键并解决浏览器之间的差异
2014/05/13 Javascript
js实现数字每三位加逗号的方法
2015/02/05 Javascript
微信WeixinJSBridge API使用实例
2015/05/25 Javascript
基于JavaScript实现跳转提示页面
2016/09/24 Javascript
用jquery快速解决IE输入框不能输入的问题
2016/10/04 Javascript
BootStrap3使用错误记录及解决办法
2016/12/22 Javascript
ionic+AngularJs实现获取验证码倒计时按钮
2017/04/22 Javascript
基于jQuery和CSS3实现APPLE TV海报视差效果
2017/06/16 jQuery
vue-cli中打包图片路径错误的解决方法
2017/10/26 Javascript
详解Vue.js项目API、Router配置拆分实践
2018/03/16 Javascript
小程序实现列表点赞功能
2018/11/02 Javascript
基于Vue实现图片在指定区域内移动的思路详解
2018/11/11 Javascript
JS 事件机制完整示例分析
2020/01/15 Javascript
Python内置函数之filter map reduce介绍
2014/11/30 Python
Python面向对象编程中的类和对象学习教程
2015/03/30 Python
使用Node.js和Socket.IO扩展Django的实时处理功能
2015/04/20 Python
python 采集中文乱码问题的完美解决方法
2016/09/27 Python
python requests 使用快速入门
2017/08/31 Python
使用pygame模块编写贪吃蛇的实例讲解
2018/02/05 Python
python实现根据文件关键字进行切分为多个文件的示例
2018/12/10 Python
Django单元测试工具test client使用详解
2019/08/02 Python
python微信公众号开发简单流程实现
2020/03/09 Python
使用pygame实现垃圾分类小游戏功能(已获校级二等奖)
2020/07/23 Python
英国和爱尔兰最大的地毯零售商:Kukoon
2018/12/17 全球购物
Python面试题:Python里面如何生成随机数
2015/03/12 面试题
电子商务专员岗位职责
2013/12/11 职场文书
大学自我鉴定
2013/12/20 职场文书
医药工作岗位求职信分享
2013/12/31 职场文书
运动会的口号
2014/06/09 职场文书
超市理货员岗位职责
2014/07/04 职场文书