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检测QQ在线状态的方法
May 09 Python
python中nan与inf转为特定数字方法示例
May 11 Python
50行Python代码实现人脸检测功能
Jan 23 Python
python实现猜单词小游戏
May 22 Python
利用python在excel里面直接使用sql函数的方法
Feb 08 Python
总结python中pass的作用
Feb 27 Python
Python3.5多进程原理与用法实例分析
Apr 05 Python
python实现kNN算法识别手写体数字的示例代码
Aug 16 Python
Python编写一个验证码图片数据标注GUI程序附源码
Dec 09 Python
浅谈tensorflow 中tf.concat()的使用
Feb 07 Python
Python日志syslog使用原理详解
Feb 18 Python
python脚本框架webpy的url映射详解
Nov 20 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
thinkphp jquery实现图片上传和预览效果
2020/07/22 PHP
ThinkPHP中图片按比例切割的代码实例
2019/03/08 PHP
div拖拽插件——JQ.MoveBox.js(自制JQ插件)
2013/05/17 Javascript
推荐一个封装好的getElementsByClassName方法
2014/12/02 Javascript
jQuery中dom元素上绑定的事件详解
2015/04/24 Javascript
Javascript对象Clone实例分析
2015/06/09 Javascript
超详细的javascript数组方法汇总
2015/11/21 Javascript
AngularJS在IE下取数据总是缓存问题的解决方法
2016/08/05 Javascript
JS基于onclick事件实现单个按钮的编辑与保存功能示例
2017/02/13 Javascript
js 调用百度分享功能
2017/02/27 Javascript
JS库中的Particles.js在vue上的运用案例分析
2017/09/13 Javascript
Vue.js在数组中插入重复数据的实现代码
2017/11/17 Javascript
利用vue开发一个所谓的数独方法实例
2017/12/21 Javascript
vue2.0实现前端星星评分功能组件实例代码
2018/02/12 Javascript
微信公众号生成新浪短网址的实现(快速生成)
2019/08/18 Javascript
解决vue elementUI 使用el-select 时 change事件的触发问题
2020/11/17 Vue.js
本地文件上传到七牛云服务器示例(七牛云存储)
2014/01/11 Python
简介Python设计模式中的代理模式与模板方法模式编程
2016/02/02 Python
Python 模板引擎的注入问题分析
2017/01/01 Python
Django自定义认证方式用法示例
2017/06/23 Python
Python找出最小的K个数实例代码
2018/01/04 Python
Python中常用信号signal类型实例
2018/01/25 Python
教你用Python创建微信聊天机器人
2020/03/31 Python
Python3之简单搭建自带服务器的实例讲解
2018/06/04 Python
python使用writerows写csv文件产生多余空行的处理方法
2019/08/01 Python
教你如何用python操作摄像头以及对视频流的处理
2020/10/12 Python
image-set实现Retina屏幕下图片显示详细介绍
2012/12/24 HTML / CSS
利用css3径向渐变做一张优惠券的示例
2018/03/22 HTML / CSS
巴西男士个人护理产品商店:SHOP4MEN
2017/08/07 全球购物
英国厨房与餐具用品为主的设计品牌:Joseph Joseph
2018/04/26 全球购物
大码女装:Ulla Popken
2019/08/06 全球购物
班主任评语大全
2014/04/26 职场文书
义诊活动总结
2015/02/04 职场文书
提档介绍信范文
2015/10/22 职场文书
深入浅析Django MTV模式
2021/09/04 Python
如何基于python实现单目三维重建详解
2022/06/25 Python