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的Flask框架构建大型Web应用程序的结构示例
Jun 04 Python
Python实现图片转字符画的示例代码
Aug 21 Python
python 寻找优化使成本函数最小的最优解的方法
Dec 28 Python
Python使用matplotlib绘制三维图形示例
Aug 25 Python
python如何发布自已pip项目的方法步骤
Oct 09 Python
Django的models模型的具体使用
Jul 15 Python
Pycharm 文件更改目录后,执行路径未更新的解决方法
Jul 19 Python
python列表每个元素同增同减和列表元素去空格的实例
Jul 20 Python
python如何将两个txt文件内容合并
Oct 18 Python
解决Pytorch自定义层出现多Variable共享内存错误问题
Jun 28 Python
Python Numpy之linspace用法说明
Apr 17 Python
python异步的ASGI与Fast Api实现
Jul 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
超外差式晶体管收音机的组装与统调
2021/03/01 无线电
桌面中心(二)数据库写入
2006/10/09 PHP
php 删除无限级目录与文件代码共享
2008/11/22 PHP
PHP filter_var() 函数 Filter 函数
2012/04/25 PHP
C#静态方法与非静态方法实例分析
2014/09/22 PHP
让Laravel API永远返回JSON格式响应的方法示例
2018/09/05 PHP
Thinkphp 框架配置操作之配置加载与读取配置实例分析
2020/05/15 PHP
javascript 去字符串空格终极版(支持utf8)
2009/11/14 Javascript
拖动table标题实现改变td的大小(css+js代码)
2013/04/16 Javascript
extJS中常用的4种Ajax异步提交方式
2014/03/07 Javascript
jquery实现的下拉和收缩效果示例
2014/08/21 Javascript
JavaScript Sort 的一个错误用法示例
2015/03/20 Javascript
有关JavaScript中call()和apply() 的一些理解
2016/05/20 Javascript
详解堆的javascript实现方法
2016/11/29 Javascript
使用jQuery的load方法设计动态加载及解决被加载页面js失效问题
2017/03/01 Javascript
js实现随机数小游戏
2019/06/28 Javascript
webpack 如何解析代码模块路径的实现
2019/09/04 Javascript
Vue通过getAction的finally来最大程度避免影响主数据呈现问题
2020/04/24 Javascript
Python日期操作学习笔记
2008/10/07 Python
Python自动化构建工具scons使用入门笔记
2015/03/10 Python
Python冒泡排序注意要点实例详解
2016/09/09 Python
Python合并同一个文件夹下所有PDF文件的方法
2019/03/11 Python
Python基于Tkinter编写crc校验工具
2020/05/06 Python
Pycharm Available Package无法显示/安装包的问题Error Loading Package List解决
2020/09/18 Python
CSS3 text shadow字体阴影效果
2016/01/08 HTML / CSS
来自全球大都市的高级街头服饰:Pegador
2018/01/03 全球购物
高二英语教学反思
2014/01/19 职场文书
中专生自我鉴定范文
2014/02/02 职场文书
银行进社区活动总结
2014/07/07 职场文书
大学拉赞助协议书范文
2014/09/26 职场文书
小学教师工作总结2015
2015/04/07 职场文书
农村党员干部承诺书
2015/05/04 职场文书
2015年学生管理工作总结
2015/05/26 职场文书
调研报告的主要写法
2019/04/18 职场文书
导游词之云南丽江古城
2019/09/17 职场文书
JavaScript数组 几个常用方法总结
2021/11/11 Javascript