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+mysql实现简单的web程序
Sep 11 Python
Python EOL while scanning string literal问题解决方法
Sep 18 Python
Python基于sftp及rsa密匙实现远程拷贝文件的方法
Sep 21 Python
Python实现的多线程http压力测试代码
Feb 08 Python
Python实现两个list对应元素相减操作示例
Jun 09 Python
Python常用字符串替换函数strip、replace及sub用法示例
May 21 Python
Python使用logging模块实现打印log到指定文件的方法
Sep 05 Python
python实现微信定时每天和女友发送消息
Apr 29 Python
Python进阶之使用selenium爬取淘宝商品信息功能示例
Sep 16 Python
用python求一重积分和二重积分的例子
Dec 06 Python
如何搭建pytorch环境的方法步骤
May 06 Python
浅谈Selenium+Webdriver 常用的元素定位方式
Jan 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 date函数参数详解
2006/11/27 PHP
PHP中用header图片地址 简单隐藏图片源地址
2008/04/09 PHP
php制作的简单验证码识别代码
2016/01/26 PHP
PHP魔术方法之__call与__callStatic使用方法
2017/07/23 PHP
php workerman定时任务的实现代码
2018/12/23 PHP
Thinkphp5框架使用validate实现验证功能的方法
2019/08/27 PHP
JS远程获取网页源代码实例
2013/09/05 Javascript
如何高效率去掉js数组中的重复项
2016/04/12 Javascript
jquery对象访问是什么及使用方法介绍
2016/05/03 Javascript
动态加载js、css的实例代码
2016/05/26 Javascript
jquery.qtip提示信息插件用法简单实例
2016/06/17 Javascript
微信小程序 WXML、WXSS 和JS介绍及详解
2016/10/08 Javascript
Vue.js中的图片引用路径的方式
2017/07/28 Javascript
JS禁止浏览器右键查看元素或按F12审查元素自动关闭页面示例代码
2017/09/07 Javascript
vue项目中用cdn优化的方法
2018/01/03 Javascript
node.js的http.createServer过程深入解析
2019/06/06 Javascript
使用js实现一个简单的滚动条过程解析
2019/09/10 Javascript
关于Vue中axios的封装实例详解
2019/10/20 Javascript
nuxt.js 在middleware(中间件)中实现路由鉴权操作
2020/11/06 Javascript
vue实现轮播图帧率播放
2021/01/26 Vue.js
[01:31:22]DOTA2-DPC中国联赛定级赛 LBZS vs Magma BO3第二场 1月10日
2021/03/11 DOTA
Python中is与==判断的区别
2017/03/28 Python
python模块之paramiko实例代码
2018/01/31 Python
Python pandas常用函数详解
2018/02/07 Python
基于python3 pyQt5 QtDesignner实现窗口化猜数字游戏功能
2019/07/15 Python
如何用Python输出一个Fibonacci数列
2016/08/28 面试题
房地产广告词大全
2014/03/19 职场文书
师德建设实施方案
2014/03/21 职场文书
计算机售后服务承诺书
2014/05/30 职场文书
学校春季防火方案
2014/06/08 职场文书
交通运输局四风问题对照检查材料思想汇报
2014/10/09 职场文书
实习生辞职信范文
2015/03/02 职场文书
大学生自我推荐信范文
2015/03/24 职场文书
电影地道战观后感
2015/06/04 职场文书
《普罗米修斯》教学反思
2016/02/22 职场文书
Python实现仓库管理系统
2022/05/30 Python