想更好的了解归并排序, 需先了解, 将两个有序列表, 组成一个有序列表

有两个列表  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的更多相关文章

  1. 归并排序(Python实现)

    目录 1. 归并排序--while版本 2. 测试用例 3. 算法时间复杂度分析 1. 归并排序--while版本 def merge_sort_while(b_list): '''归并排序--whi ...

  2. 排序算法之归并排序的python实现

    采用分治法: 分割:递归地把当前序列平均分割成两半. 集成:在保持元素顺序的同时将上一步得到的子序列集成到一起(归并). 归并操作(归并算法),指的是将两个已经排序的序列合并成一个序列的操作.归并排序 ...

  3. 归并排序算法-python实现

    #-*- coding: UTF-8 -*- import numpy as np def Merge(a, f, m, l): i = f j = m + 1 tmp = [] while i &l ...

  4. python数据结构与算法——归并排序

    归并排序: 原理与C语言实现 参考:白话经典算法系列之五 归并排序的实现 1. 容易对有序数组A,B进行排序. 2. 为了使得A,B组内数据有序:可以将A,B组各自再分成二组. 3. 经过不断分组,当 ...

  5. 你需要知道的九大排序算法【Python实现】之归并排序

    四.归并排序 基本思想:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的.然后再把有序子序列合并为整体有序序列.归并过程:比 ...

  6. JavaScript算法 ,Python算法,Go算法,java算法,系列之【归并排序】篇

    常见的内部排序算法有:插入排序.希尔排序.选择排序.冒泡排序.归并排序.快速排序.堆排序.基数排序等.用一张图概括: 归并排序(英语:Merge sort,或mergesort),是创建在归并操作上的 ...

  7. python实现折半查找算法&&归并排序算法

    今天依旧是学算法,前几天在搞bbs项目,界面也很丑,评论功能好像也有BUG.现在不搞了,得学下算法和数据结构,笔试过不了,连面试的机会都没有…… 今天学了折半查找算法,折半查找是蛮简单的,但是归并排序 ...

  8. python实现归并排序,归并排序的详细分析。

    学习归并排序的过程是十分痛苦的.它并不常用,看起来时间复杂度好像是几种排序中最低的,比快排的时间复杂度还要低,但是它的执行速度不是最快的.很多朋友不理解时间复杂度低为什么运行速度不一定快,这个不清楚的 ...

  9. 高速排序,归并排序,堆排序python实现

    高速排序的时间复杂度最好情况下为O(n*logn),最坏情况下为O(n^2),平均情况下为O(n*logn),是不稳定的排序 归并排序的时间复杂度最好情况下为O(n*logn),最坏情况下为O(n*l ...

随机推荐

  1. centos7配置网易yum源

    部分参考centos6: https://blog.csdn.net/jinzhencs/article/details/53673999 下载yum:  https://www.cnblogs.co ...

  2. sqlserver2012 数据库差异备份恢复 记录

    sqlserver2012恢复过程: 先恢复全备份,再恢复差异,注意:勾选NoRecovery选项. 恢复完成后,出现: Sqlserver数据库 一直显示“正在还原…” 的状态. 引用:http:/ ...

  3. stylus含有的特性

    Stylus 冒号可有可无 分号可有可无 逗号可有可无 括号可有可无 变量 插值(Interpolation) 混合(Mixin) 数学计算 强制类型转换 动态引入 条件表达式 迭代 嵌套选择器 父级 ...

  4. 在Centos7上安装wxPython4.0.4

    在linux上安装wxPython4.0.4时需要gtk+2.0,在安装wxPython4.0.4遇到以下错误. linux上是用pip安装wxPython4.0.4的,执行命令如下: pip ins ...

  5. java将错误信息写入文件

    第一种办法可以通过字符串,也就是先把错误信息写入字符串,再将字符串写入文件 import java.io.*; public class Demo { public static void main( ...

  6. js前台计算两个日期的间隔时间

    js前台计算两个日期的间隔时间(时间差)原创 2017年08月28日 16:09:43 标签:javascript 1144在后台传来两个时间字段,从中解析出两个字符串类型的日期格式 需要在前台解析出 ...

  7. Python 学习笔记02篇

    之前很庆幸早点报名课程 可以早点看到视频讲解,不至于后期太赶 不得不说原本21天压缩到14天再压缩到7天,如果可以完整且独立地完成至少三个作业,那水平应该真的很不错吧

  8. SQL Server中与IO相关的等待类型:IO_COMPLETION和PAGEIOLATCH_*

    一个大的SQL语句操作,执行计划中包含了一个merge join操作,观察到SQL长时间处于IO_COMPLETION等待状态,如果是读取相关的表的数据,服务器应该全力为其服务,但是服务器的物理IO又 ...

  9. cv2.error: openCV报错

    运行openCV程序,出现了.cv2.error: OpenCV(4.1.0) D:\Build\OpenCV\opencv-4.1.0\modules\imgproc\src\color.cpp:1 ...

  10. Quartz与Spring集成(二)

    一.获取quartz详情jar <!-- quartz 的jar --> <dependency> <groupId>org.quartz-scheduler< ...