python排序算法之归并排序

作者:i阿极 时间:2021-03-24 06:05:39 

一、前言

相关知识来自《python算法设计与分析》。初级排序算法是指几种较为基础且容易理解的排序算法。初级排序算法包括插入排序、选择排序和冒泡排序3种。相比起初级排序算法,高级排序算法往往有更加复杂的逻辑,但也会有更高的时间或空间效率。其中有些高级排序算法是由一些初级排序算法优化而来的。

二、算法描述

本节中的第一种高级排序算法是归并排序。“归并”一词,意为“合并”。顾名思义,归并排序算法就是一个先把数列拆分为子数列,对子数列进行排序后,再把有序的子数列合并为完整的有序数列的算法。它实际上采用了分治的思想。

归并排序的平均时间复杂度是O(nlgn),最好情况下的时间复杂度是O(nlgn),最坏情况下的时间复杂度也是O(nlgn)。它的空间复杂度是O(1)。另外,归并排序还是一个稳定的排序算法。

以升序排序为例,归并算法的流程如图2-21所示。

原始数组是一个有8个数的无序数组。一次操作后,把8个数的数组分成两个4个数组成的无序数组。接下来的每次操作都是把无序数组不停分成两半,直到每个最小的数组里都只有一个元素为止。当数组里只有一个元素时,这个数组必定是有序的。然后,程序开始把小的有序数组每两个合并成为大的有序数组。先是从两个1个数的数组合并成2个数的数组,再到4个数然后8个数。这时,所有的有序数组全部合并完成,最后产生的最长的有序数组就排序完成了。

python排序算法之归并排序

三、代码实现

归并排序代码:

#归并排序
nums = [5,3,6,4,1,2,8,7]
def MergeSort(num):
 if(len(num)<=1):#递归边界条件
  return num#到达边界时返回当前的子数组
 mid = int(len(num)/2) #求出数组的中位数
 llist,rlist = MergeSort(num[:mid]),MergeSort(num[mid:])#调用函数分别为左右数组排序
 result = []
 i,j = 0,0
 while i < len(llist) and j < len(rlist): #while循环用于合并两个有序数组
  if rlist[j]<llist[i]:
    result.append(rlist[j])
    j += 1
  else:
    result.append(llist[i])
    i += 1
 result += llist[i:]+rlist[j:] #把数组未添加的部分加到结果数组末尾
 return result#返回已排序的数组
print(MergeSort(nums))

运行程序,输出结果为:

[1,2,3,4,5,6,7,8]

在MergeSort()函数中,首先进行的是边界条件判断。当传入函数的数组长度只有1时,每一个数独立存在于一个数组中,因此数组已经被分到最小。这时候,递归分解数组的任务已经完成,只需要把分解后的数组返回到上一层递归就可以了。

如果未排序数组的长度仍然大于1,那么使用变量mid来存储数组最中间的下标,把未排序数组分成左右两个子数组。然后,新建两个数组,用于存储排好序的左右子数组。这里使用了递归的思想。我们只把MergeSort()函数视为一个为列表排序的函数,尽管在MergeSort()函数内部,也可以调用函数本身对两个子数组进行排序。

随后,使用while循环合并两个已经有序的数组。由于不能确定两个数组中元素的相对大小,所以我们采用i和j两个变量分别标记在左子数组和右子数组中等待加入的元素的位置。当while循环结束时,可能一个子数组的末尾还剩余一些最大的元素没有被添加到result列表中,所以result+=llist[i:]+rlist[j:]语句是为了防止漏掉这些元素。数组合并完成后,函数输出有序数组。

来源:https://blog.csdn.net/AOAIYI/article/details/128657679

标签:python,排序,算法,归并
0
投稿

猜你喜欢

  • SQL2005查询表结构的SQL语句使用分享

    2024-01-15 21:47:52
  • 使用OpenCV获取图片连通域数量,并用不同颜色标记函

    2023-10-17 19:58:05
  • Python 创建子进程模块subprocess详解

    2022-02-21 06:47:39
  • 基于python分布式爬虫并解决假死的问题

    2021-06-28 03:38:28
  • Mysql数据库锁定机制详细介绍

    2024-01-27 00:57:59
  • JS验证逗号隔开可以是中文字母数字

    2024-04-19 10:48:08
  • ORACLE 常用的SQL语法和数据对象

    2009-02-26 10:58:00
  • python通过微信发送邮件实现电脑关机

    2022-03-20 17:58:37
  • Python实现将DNA序列存储为tfr文件并读取流程介绍

    2021-08-04 08:02:23
  • Python实现url长短链接的转换

    2022-07-21 14:05:58
  • Python离线安装openpyxl模块的步骤

    2021-08-10 16:04:04
  • ASP程序员面试题

    2011-09-15 20:51:20
  • 一文详解如何创建自己的Python装饰器

    2021-09-10 02:43:43
  • 浅谈Python中range和xrange的区别

    2021-04-18 14:52:13
  • ASP下批量删除数据的两种方法

    2011-02-05 11:01:00
  • 解决python中使用PYQT时中文乱码问题

    2023-07-28 10:15:51
  • python 3.3 下载固定链接文件并保存的方法

    2023-09-22 16:43:50
  • python tkinter与Mysql数据库交互实现账号登陆

    2024-01-21 19:02:39
  • Java+mysql本地图片上传数据库及下载示例

    2023-07-23 19:49:13
  • python如何使用socketserver模块实现并发聊天

    2022-06-23 08:58:41
  • asp之家 网络编程 m.aspxhome.com