归并排序之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 ...
随机推荐
- C#解析json和xml数据
C#解析json和xml数据 // 用到的包using Newtonsoft.Json; // using Newtonsoft.Json.Linq; const string value = &qu ...
- 初次接触Linux
最近由于工作需求,需要接触Linux系统. 使用VMware虚拟机,安装ubuntu系统.网上教程很多. 配置opencv环境.这是我参考的网上帖子https://blog.csdn.net/fish ...
- 纠结了一下午的问题:运行opencv的HoughLinesP函数出错
问题描述:检测出的直线数量显然不对,非常巨大.程序运行崩溃. 解决办法:在添加附加依赖项时,Dubug模式只添加opencv_world310d.lib,Release模式下只添加opencv_wor ...
- MSSQL 表修复语句
一早发现C盘爆满了,查询了下发现是mssql下面占用了几十G的log以及mdmp文件 一般发现这种文件就是代表着数据库出问题了. 检查数据库,发现某个数据库有问题,(回想起来前天做了一个操作,可能有问 ...
- socket.io诡异的问题
在socket.io客户端连接的时候,如果传入的query包含“sid”这个键时会报错,不知道具体原因.
- 关于Qrc文件的用法
在python文件xxx.py中调用资源文件,一般来说,需要将资源放在xxx.py的相同目录下:然而,当在xxx.py下建立一个统一目录/rec则需要建立xxx.qrc文件才能让xxx.py调用,调用 ...
- 安装SQL server 2008 R2和QL server 2008,与SQL server 2008升级SQL server 2008 R2
安装SQL server 2008 R2和由SQL server 2008升级SQL server 2008 R2 前提条件: 由SQL server2008 升级SQL server2008 R2 ...
- 转载:C# socket端口复用-多主机头绑定
什么是端口复用: 因为在winsock的实现中,对于服务器的绑定是可以多重绑定的,在确定多重绑定使用谁的时候,根据一条原则是谁的指定最明确则将包递交给谁,而且没有权限之分.这种多重绑定便称之为端口复用 ...
- Spring的诞生
前言:不先学习常见的设计模式直接看Spring.MyBatis等源码,简直就是一个找虐的过程!不掌握Servlet原理.基本的Tomcat容器技术上来就看Spring MVC源码同样也是一个打击自信心 ...
- 安装VMware tools
1.发现在vmware中无法复制粘贴,经查询后Centos精简版是没有VMware tools的.2.df是用来看磁盘空间使用情况的.3.rpm包的格式:name+version(主版本+此版本+修正 ...