归并排序之python
想更好的了解归并排序, 需先了解, 将两个有序列表, 组成一个有序列表
有两个列表 l1 = [1, 3, 5, 7]
l2 = [2, 4, 6]
需要将 l1 和 l2 组成一个 有序大列表 l = [1, 2, 3, 4, 5, 6, 7]
注意,前提 l1 和 l2 两个列表已经排好序, 是有序列表
def merge(l1, l2):
# 两个列表, 两个初始索引号, 赋值 0
l1_index, l2_index = 0, 0
# 存放结果的新的空列表
result = []
# 循环, 两个索引值都要小于各自列表的长度
while l1_index < len(l1) and l2_index < len(l2):
# 小的数值,则添加到结果列表中, 并把小列表 的索引+1,
# 这样 小列表就指向下一个数据, 和 另一个列表的的数值再次比较
if l1[l1_index] < l2[l2_index]:
result.append(l1[l1_index])
l1_index += 1
else:
result.append(l2[l2_index])
l2_index += 1 # l1 和 l2 长度可能相等, 也可能不等
# 但是经过while循环后, l1_index 和 l2_index
# 最少有一个,已经到列表的末尾
# 所以,如下对两个列表的最后切片取值,
# 最少有一个是空列表,
# 直接列表相加, 就省去了判断代码逻辑
result += l1[l1_index:]
result += l2[l2_index:]
return result print(merge([1, 3, 5, 7], [2, 4, 6]))
归并排序的递归算法实现,
直接使用了上面代码的合并 merge 函数
def mergesort(lists):
# 如果列表长度小于等于1
# 说明列表是空列表, 或只有一个元组
# 则不需要排序,直接返回原列表
if len(lists) <= 1:
return lists
# 列表长度除以2
num = int(len(lists) / 2)
# 将列表一分为二,
# 再分别对这两个列表进行归并排序
left = mergesort(lists[:num])
right = mergesort(lists[num:])
# 注意,这是递归算法
# left 和 right 变成只有一个元素的列表值的时候
# 或者, left 和 right 都已是有序列表
# 调用merge函数
# 可以打印, left 和 right 的值看看,
# 感受, left 和 right 的变化
# print(left, right)
return merge(left, right) print(mergesort([3, 1, 4]))
print(mergesort([3, 1, 4, 2]))
归并排序, 将一个列表 一分为二, 分别对两个新列表进行归并排序, 然后 将这 两个排序后的新列表 进行 合并.
两个被拆分的 新列表 再次进行归并排序, 直至递归到只有一个元素的情况,
最后, 由最后的两个元素, 开始 合并, 逐层 向上 合并, 实现全部排序
痛点: 是对递归算法的了解
归并排序之python的更多相关文章
- 归并排序(Python实现)
目录 1. 归并排序--while版本 2. 测试用例 3. 算法时间复杂度分析 1. 归并排序--while版本 def merge_sort_while(b_list): '''归并排序--whi ...
- 排序算法之归并排序的python实现
采用分治法: 分割:递归地把当前序列平均分割成两半. 集成:在保持元素顺序的同时将上一步得到的子序列集成到一起(归并). 归并操作(归并算法),指的是将两个已经排序的序列合并成一个序列的操作.归并排序 ...
- 归并排序算法-python实现
#-*- coding: UTF-8 -*- import numpy as np def Merge(a, f, m, l): i = f j = m + 1 tmp = [] while i &l ...
- python数据结构与算法——归并排序
归并排序: 原理与C语言实现 参考:白话经典算法系列之五 归并排序的实现 1. 容易对有序数组A,B进行排序. 2. 为了使得A,B组内数据有序:可以将A,B组各自再分成二组. 3. 经过不断分组,当 ...
- 你需要知道的九大排序算法【Python实现】之归并排序
四.归并排序 基本思想:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的.然后再把有序子序列合并为整体有序序列.归并过程:比 ...
- JavaScript算法 ,Python算法,Go算法,java算法,系列之【归并排序】篇
常见的内部排序算法有:插入排序.希尔排序.选择排序.冒泡排序.归并排序.快速排序.堆排序.基数排序等.用一张图概括: 归并排序(英语:Merge sort,或mergesort),是创建在归并操作上的 ...
- python实现折半查找算法&&归并排序算法
今天依旧是学算法,前几天在搞bbs项目,界面也很丑,评论功能好像也有BUG.现在不搞了,得学下算法和数据结构,笔试过不了,连面试的机会都没有…… 今天学了折半查找算法,折半查找是蛮简单的,但是归并排序 ...
- python实现归并排序,归并排序的详细分析。
学习归并排序的过程是十分痛苦的.它并不常用,看起来时间复杂度好像是几种排序中最低的,比快排的时间复杂度还要低,但是它的执行速度不是最快的.很多朋友不理解时间复杂度低为什么运行速度不一定快,这个不清楚的 ...
- 高速排序,归并排序,堆排序python实现
高速排序的时间复杂度最好情况下为O(n*logn),最坏情况下为O(n^2),平均情况下为O(n*logn),是不稳定的排序 归并排序的时间复杂度最好情况下为O(n*logn),最坏情况下为O(n*l ...
随机推荐
- 6.3 基于二分搜索树、链表的实现的集合Set复杂度分析
两种集合类的复杂度分析 在[6.1]节与[6.2]节中分别以二分搜索树和链表作为底层实现了集合Set,在本节就两种集合类的复杂度分析进行分析:测试内容:6.1节与6.2节中使用的书籍.测试方法:测试两 ...
- 9Linux_LVM_iptables
LVM 创建物理卷 卷组 逻辑卷 格式化 挂载 扩容 缩小 快照 删除逻辑卷
- a 标签实现分享功能
在网页中,经常会用到分享功能,例如分享到qq,分享到微信,分享到微博等,但是怎么实现呢?一直没有想清楚这个问题,觉得好高大上的样子,于是在网上找了一些资料,也没有看出个什么所以然来: 于是有些心急了, ...
- linux上如何设置网络,出现connect: network is unreachable 的问题。
发现有网友问有关ping命令出现connect: network is unreachable 的问题. 这通常是因为没正确设置ip地址. 解决方法: 在确保完善网卡驱动,以及确保将网卡驱动编译进内核 ...
- K-Means算法:图片压缩
#读取实例图片# from sklearn.datasets import load_sample_image from sklearn.cluster import KMeans import ma ...
- [phvia/dkc] Docker Compose 快速构建(LNMP+Node)运行环境
快速构建(LNMP+Node)运行环境. dkc 在此作为 docker-compose 的缩写,你可以理解为 alias dkc=docker-compose 准备 安装 docker 选择1) 从 ...
- pop() 删除掉数组的最后一个元素
下面的代码首先创建了一个拥有四个元素的数组 myFish,然后删除掉它的最后一个元素. let myFish = ["angel", "clown", &quo ...
- 什么是云?Iaas,Paas和SaaS
周围的朋友听说我是做云相关的,总是爱问啥是云?别不是虚幻的概念吧.云计算当然不是虚幻的概念,“云”其实是互联网的一个隐喻,简单地说,云计算是通过Internet(“云”)交付计算服务——服务器.存储. ...
- 执行多条SQL语句,实现数据库事务(不可传入Sql参数)
执行多条SQL语句,实现数据库事务(不可传入Sql参数) http://blog.csdn.net/hanxuemin12345/article/details/9980371
- vue环境项目启动后因为eslint语法限制报错
报错太多,截取了一部分. 解决方法找到项目根目录的build 找到webpack.base.conf.js 打开js文件找到下图的位置 再重新启动项目就好了