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编写暴力破解FTP密码小工具
Nov 19 Python
在Python中使用next()方法操作文件的教程
May 24 Python
python删除过期文件的方法
May 29 Python
Python连接数据库学习之DB-API详解
Feb 07 Python
Python编写Windows Service服务程序
Jan 04 Python
django中模板的html自动转意方法
May 27 Python
基于python绘制科赫雪花
Jun 22 Python
pandas.dataframe按行索引表达式选取方法
Oct 30 Python
python 定时器,实现每天凌晨3点执行的方法
Feb 20 Python
Python matplotlib生成图片背景透明的示例代码
Aug 30 Python
在python3.64中安装pyinstaller库的方法步骤
Jun 02 Python
使用pandas实现筛选出指定列值所对应的行
Dec 13 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设计模式 Mediator (中介者模式)
2011/06/26 PHP
thinkphp区间查询、统计查询与SQL直接查询实例分析
2014/11/24 PHP
详解php curl带有csrf-token验证模拟提交方法
2018/04/18 PHP
php 使用ActiveMQ发送消息,与处理消息操作示例
2020/02/23 PHP
js传值 判断
2006/10/26 Javascript
认识延迟时间为0的setTimeout
2008/05/16 Javascript
Javascript 强制类型转换函数
2009/05/17 Javascript
解决IE下select标签innerHTML插入option的BUG(兼容IE,FF,Opera,Chrome,Safari)
2010/05/13 Javascript
jquery和javascript的区别(常用方法比较)
2013/07/04 Javascript
多种方法判断Javascript对象是否存在
2013/09/22 Javascript
多个$(document).ready()的执行顺序实例分析
2014/07/26 Javascript
javascript学习笔记(一)基础知识
2014/09/30 Javascript
js获取元素外链样式的方法
2015/01/27 Javascript
javascript修改图片src的方法
2015/01/27 Javascript
JavaScript实现数组在指定位置插入若干元素的方法
2015/04/06 Javascript
JavaScript实现简单的拖动效果
2016/07/02 Javascript
微信小程序之仿微信漂流瓶实例
2016/12/09 Javascript
JS简单获取当前日期时间的方法(如:2017-03-29 11:41:10 星期四)
2017/03/29 Javascript
C#实现将一个字符转换为整数
2017/12/12 Javascript
element ui 表格动态列显示空白bug 修复方法
2018/09/04 Javascript
微信小程序自定义toast的实现代码
2018/11/16 Javascript
js使用swiper实现层叠轮播效果实例代码
2018/12/12 Javascript
layui写后台表格思路和赋值用法详解
2019/11/14 Javascript
[01:01:51]EG vs VG Supermajor小组赛B组 BO3 第二场 6.2
2018/06/03 DOTA
Python 连连看连接算法
2008/11/22 Python
python爬虫使用cookie登录详解
2017/12/27 Python
Python实现七彩蟒蛇绘制实例代码
2018/01/16 Python
Pandas:DataFrame对象的基础操作方法
2018/06/07 Python
Tensorflow实现神经网络拟合线性回归
2019/07/19 Python
TensorFLow 数学运算的示例代码
2020/04/21 Python
人事档案接收函
2014/01/12 职场文书
《蒙娜丽莎之约》教学反思
2014/02/27 职场文书
自动化专业大学生职业生涯规划范文:爱拚才会赢
2014/09/12 职场文书
离婚协议书该怎么写
2014/10/04 职场文书
老生常谈 使用 CSS 实现三角形的技巧(多种方法)
2021/04/13 HTML / CSS
python 解决微分方程的操作(数值解法)
2021/05/26 Python