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的多态性实例分析
Jul 07 Python
windows系统下Python环境的搭建(Aptana Studio)
Mar 06 Python
R语言 vs Python对比:数据分析哪家强?
Nov 17 Python
python实现画圆功能
Jan 25 Python
python生成不重复随机数和对list乱序的解决方法
Apr 09 Python
详解用TensorFlow实现逻辑回归算法
May 02 Python
Python实现聊天机器人的示例代码
Jul 09 Python
利用rest framework搭建Django API过程解析
Aug 31 Python
PyCharm GUI界面开发和exe文件生成的实现
Mar 04 Python
Python函数参数定义及传递方式解析
Jun 10 Python
python virtualenv虚拟环境配置与使用教程详解
Jul 13 Python
Python类class参数self原理解析
Nov 19 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日历类分享
2014/11/18 PHP
php实现按照权重随机排序数据的方法
2015/01/09 PHP
PHP使用pear自带的mail类库发邮件的方法
2015/07/08 PHP
PHP仿微信发红包领红包效果
2016/10/30 PHP
php把时间戳转换成多少时间之前函数的实例
2016/11/16 PHP
php ActiveMQ的安装与使用方法图文教程
2020/02/23 PHP
xmlHTTP实例
2006/10/24 Javascript
基于jQuery图片平滑连续滚动插件
2009/04/27 Javascript
JavaScipt中的Math.ceil() 、Math.floor() 、Math.round() 三个函数的理解
2010/04/29 Javascript
改善用户体验的五款jQuery插件分享
2011/05/22 Javascript
服务器端的JavaScript脚本 Node.js 使用入门
2012/03/07 Javascript
个人总结的一些JavaScript技巧、实用函数、简洁方法、编程细节
2015/06/10 Javascript
jQuery实现简单的网页换肤效果示例
2016/09/18 Javascript
什么是JavaScript中的结果值?
2016/10/08 Javascript
JS中BOM相关知识点总结(必看篇)
2016/11/22 Javascript
layer.prompt输入层的例子
2019/09/24 Javascript
vue移动端使用appClound拉起支付宝支付的实现方法
2019/11/21 Javascript
React Native中ScrollView组件轮播图与ListView渲染列表组件用法实例分析
2020/01/06 Javascript
简单了解Vue + ElementUI后台管理模板
2020/04/07 Javascript
Node.js API详解之 readline模块用法详解
2020/05/22 Javascript
JavaScript Array.flat()函数用法解析
2020/09/02 Javascript
JavaScript 实现轮播图特效的示例
2020/11/05 Javascript
使用python的chardet库获得文件编码并修改编码
2014/01/22 Python
Python程序设计入门(5)类的使用简介
2014/06/16 Python
Python import自定义模块方法
2015/02/12 Python
Python中MySQLdb和torndb模块对MySQL的断连问题处理
2015/11/09 Python
python 全局变量的import机制介绍
2017/09/07 Python
法国在线宠物店:zooplus.fr
2018/02/23 全球购物
Java面试题汇总
2015/12/06 面试题
自我鉴定200字
2013/10/28 职场文书
幼儿如何来做好自我评价
2013/11/05 职场文书
公司人力资源的自我评价
2014/01/02 职场文书
甜品蛋糕店创业计划书范文
2014/02/06 职场文书
党员承诺书怎么写
2014/05/20 职场文书
Python 实现绘制子图及子图刻度的变换等问题
2021/05/31 Python
Python学习之迭代器详解
2022/04/01 Python