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中序列与字典的相同和不同之处
Jan 19 Python
python如何通过protobuf实现rpc
Mar 06 Python
利用Python破解斗地主残局详解
Jun 30 Python
对python中list的拷贝与numpy的array的拷贝详解
Jan 29 Python
python SVM 线性分类模型的实现
Jul 19 Python
django之状态保持-使用redis存储session的例子
Jul 28 Python
python数据归一化及三种方法详解
Aug 06 Python
通过实例了解python property属性
Nov 01 Python
Series和DataFrame使用简单入门
Nov 13 Python
Python参数传递及收集机制原理解析
Jun 05 Python
python 将html转换为pdf的几种方法
Dec 29 Python
MATLAB 如何求取离散点的曲率最大值
Apr 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 创建以UNIX时间戳命名的文件夹(示例代码)
2014/03/08 PHP
常见php数据文件缓存类汇总
2014/12/05 PHP
ZendFramework2连接数据库操作实例
2017/04/18 PHP
浅谈PHP进程管理
2019/03/08 PHP
PHP 模拟登陆功能实例详解
2019/09/10 PHP
来自国外的14个图片放大编辑的jQuery插件整理
2010/10/20 Javascript
js分页代码分享
2014/04/28 Javascript
JS显示下拉列表框内全部元素的方法
2015/03/31 Javascript
jQuery ajax MD5实现用户注册即时验证功能
2016/10/11 Javascript
angular+bootstrap的双向数据绑定实例
2017/03/03 Javascript
使用vue构建移动应用实战代码
2017/08/02 Javascript
基于webpack 实用配置方法总结
2017/09/28 Javascript
ionic3+Angular4实现接口请求及本地json文件读取示例
2017/10/11 Javascript
Angular简单验证功能示例
2017/12/22 Javascript
vue+axios实现post文件下载
2019/09/25 Javascript
JS window对象简单操作完整示例
2020/01/14 Javascript
用Python写的图片蜘蛛人代码
2012/08/27 Python
Django 过滤器汇总及自定义过滤器使用详解
2019/07/19 Python
tensorflow实现打印ckpt模型保存下的变量名称及变量值
2020/01/04 Python
python+opencv实现移动侦测(帧差法)
2020/03/20 Python
Python爬虫入门有哪些基础知识点
2020/06/02 Python
Python爬虫逆向分析某云音乐加密参数的实例分析
2020/12/04 Python
一款CSS3实现多功能下拉菜单(带分享按)的教程
2014/11/05 HTML / CSS
canvas裁剪clip()函数的具体使用
2018/03/01 HTML / CSS
Sixt美国租车:高端豪华车型自驾体验
2017/09/02 全球购物
大学生职业生涯设计书
2014/01/02 职场文书
企业给企业的表扬信
2014/01/13 职场文书
企业业务员岗位职责
2014/03/14 职场文书
网络编辑求职信
2014/04/30 职场文书
银行招聘自荐信
2015/03/06 职场文书
酒店优秀员工推荐信
2015/03/24 职场文书
社区敬老月活动总结
2015/05/07 职场文书
学习党史心得体会2016
2016/01/23 职场文书
如何撰写促销方案?
2019/07/05 职场文书
使用pytorch实现线性回归
2021/04/11 Python
如何用Node.js编写内存效率高的应用程序
2021/04/30 Javascript