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 threading模块操作多线程介绍
Apr 08 Python
Python连接mysql数据库的正确姿势
Feb 03 Python
Python中死锁的形成示例及死锁情况的防止
Jun 14 Python
实例讲解Python的函数闭包使用中应注意的问题
Jun 20 Python
解决pandas read_csv 读取中文列标题文件报错的问题
Jun 15 Python
Python定时任务随机时间执行的实现方法
Aug 14 Python
python实现ip地址查询经纬度定位详解
Aug 30 Python
python3图片文件批量重命名处理
Oct 31 Python
在python里创建一个任务(Task)实例
Apr 25 Python
TensorFlow Autodiff自动微分详解
Jul 06 Python
详解anaconda离线安装pytorchGPU版
Sep 08 Python
python 爬取天气网卫星图片
Jun 07 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/03/03 PHP
PHP实现动态柱状图改进版
2015/03/30 PHP
javascript 传统事件模型构造的事件监听器实现代码
2010/05/31 Javascript
jQuery下的动画处理总结
2013/10/10 Javascript
JavaScript中常见获取元素的方法汇总
2015/03/04 Javascript
整理Javascript数组学习笔记
2015/11/29 Javascript
实例解析angularjs的filter过滤器
2016/12/14 Javascript
jquery.validate表单验证插件使用详解
2017/06/21 jQuery
input输入框内容实时监测(附代码)
2017/08/15 Javascript
获取本机IP地址的实例(JavaScript / Node.js)
2017/11/24 Javascript
nodejs基础之buffer缓冲区用法分析
2018/12/26 NodeJs
在vue项目中引入vue-beauty操作方法
2019/02/11 Javascript
在vue中使用防抖和节流,防止重复点击或重复上拉加载实例
2019/11/13 Javascript
JavaScript(js)处理的HTML事件、键盘事件、鼠标事件简单示例
2019/11/19 Javascript
浅谈React中组件逻辑复用的那些事儿
2020/05/21 Javascript
JavaScript装箱及拆箱boxing及unBoxing用法解析
2020/06/15 Javascript
Nuxt的路由配置和参数传递方式
2020/11/06 Javascript
JavaScript实现鼠标经过表格某行时此行变色
2020/11/20 Javascript
[00:32]2018DOTA2亚洲邀请赛Liquid出场
2018/04/03 DOTA
Python的SQLAlchemy框架使用入门
2015/04/29 Python
Python中防止sql注入的方法详解
2017/02/25 Python
win10下Python3.6安装、配置以及pip安装包教程
2017/10/01 Python
Python基础教程之异常详解
2019/01/10 Python
python实现顺时针打印矩阵
2019/03/02 Python
win10环境下配置vscode python开发环境的教程详解
2019/10/16 Python
python实现双色球随机选号
2020/01/01 Python
Python3 实现爬取网站下所有URL方式
2020/01/16 Python
python_matplotlib改变横坐标和纵坐标上的刻度(ticks)方式
2020/05/16 Python
如何将字串String转换成整数int
2015/02/21 面试题
土地租赁意向书
2014/07/30 职场文书
老龄工作先进事迹
2014/08/15 职场文书
爱国影片观后感
2015/06/18 职场文书
公司员工宿舍管理制度
2015/08/03 职场文书
2016元旦晚会主持人开场白和结束语
2015/12/03 职场文书
PyQt5 显示超清高分辨率图片的方法
2021/04/11 Python
golang goroutine顺序输出方式
2021/04/29 Golang