Python数据结构【四】排序(二)难度:困难

文章目录

  • 前言
    • 一、书接上回
    • 二、快速排序(Quick Sort)
      • 2.1 快速排序思想
      • 2.2 快速排序代码实现
      • 2.3 快速排序复杂度分析
    • 三、堆排序(Heap Sort)
      • 3.1 堆排序思想
      • 3.2 堆排序代码实现
      • 3.3 堆排序复杂度分析
  • 结语

前言

可私聊进一千多人Python全栈交流群(手把手教学,问题解答)

可私聊获取源代码和动画PPT进群可领取Python全栈教程视频 + 多得数不过来的计算机书籍:基础、Web、爬虫、数据分析、可视化、机器学习、深度学习、人工智能、算法、面试题等。

  • 🚀🚀加入我一起学习进步,一个人可以走的很快,一群人才能走的更远!

  • 一、书接上回

    上次学习了冒泡排序,插入排序,选择排序,今天需要学习的是快速排序,堆排序。

    相比于前面三个,这两个可以说是有一点点难度的了。

    二、快速排序(Quick Sort)

    快速排序,突出的就是一个快字,比前面三个时间复杂度少一点,因为快排使用了类似于二分+递归的方法。

    2.1 快速排序思想

    1. 取出一个元素(通常是第一个)

    2. 然后将该元素放入一个位置使得左边的元素都小于该元素,右边的元素都大于该元素

    3. 然后对该元素左右两边进行切割

    4. 然后递归

    5. 结束

    整了个动画来讲解第二步

    在这里插入图片描述

    2.2 快速排序代码实现

    由于第二步功能较多,所以我们可以使用一个函数封装起来。

    找中位数函数(也就是动图的实现)

    def find_mid(left, right, li):"""left: 左指针right: 右指针li: 列表之所以不是0和n-1是为了递归的时候也能使用"""swep = False                        # 代表左边有无空temp = li[left]while left < right:                 # 循环终止条件if swep == False:               # 如果左边有空位if li[right] < temp:        # 判断是否可以交换li[right],li[left] = li[left],li[right]     # 交换swep = True             # 左边无空位else:right -= 1                # 不交换,左边有空位,右指针移动else:                           # 左边无空位if li[left] > temp:         # 判断li[left],li[right] = li[right],li[left]     # 交换swep = False            # 左边有空位else:left += 1               # 无法腾出空位,左指针移动li[left] = temp                     # 找到位置,将元素插入return left                         # 此时左右重合,退出函数
    

    快排递归函数:

    def quick_sort(left, right, li):if left < right:                    # 递归终止条件mid = find_mid(left, right, li)quick_sort(left, mid-1, li)     # 排序左边的quick_sort(mid+1, right, li)    # 排序右边的
    

    测试用例:[5, 4, 2, 8, 3, 9]

    运行结果:

    在这里插入图片描述

    测试用例:[1, 1, 4, 5, 1, 4]

    运行结果:

    在这里插入图片描述

    2.3 快速排序复杂度分析

    时间复杂度:nlogn

    空间复杂度:nlogn (实际上这个是递归的空间复杂度,因为原地排序是不需要空间复杂度的)

    当然这些都是算平均的复杂度,时间上算法的时间空间复杂度都是由最优和最劣的情况的,这里就不一一赘述了

    三、堆排序(Heap Sort)

    堆排序,就是使用堆来进行排序的一种排序方法。

    • 堆——堆是一种特殊的完全二叉树
      • 大根堆——一种完全二叉树,满足任意节点都比孩子节点大
      • 小根堆——一种完全二叉树,满足其任意节点都比孩子节点小

    在这里插入图片描述

    当然树这个数据结构是没有箭头的,我只是想起来已经做出来了就懒得重做了。

    3.1 堆排序思想

    通过堆的向下调整来排序。(左右子树都满足大/小根堆,但是堆本身不满足)

    1. 建立一个堆(需要从小到大排就建立小根堆,需要从大到小就建立大根堆)
    2. 得到堆顶元素(此时堆是大根/小根堆,是有序的)
    3. 将堆顶元素去掉,替换为堆最后的元素,进行堆的向下调整(此时堆顶元素为最大/最小元素)
    4. 重复步骤2,3,直到堆为空(使用递归,判断根节点是否为空)

    由于堆的向下调整比较难,所以只做一个向下调整的演示动画。

    在这里插入图片描述

    如果将上述堆通过列表展示,则列表为:[2, 5, 4, 3, 8, 7]

    从根节点向下,然后每个子树都完全展示出来

    3.2 堆排序代码实现

    向下调整函数:

    def change_down(li, low, high):"""li: 无序数组low: 根节点元素high: 最后一个元素位置"""temp = li[low]                               # 存起来栈顶元素i = low                                      # i指向根节点j = 2 *i + 1                                 # j指向左孩子节点while j <= high:                             # 只要j不为空if j + 1 <= high and li[j+1] > li[j]:    # 如果右孩子节点大j = j + 1                            # j指向右孩子节点  if li[j] > temp:                         # 如果左孩子节点大li[i] = li[j]                        # 将大的放在栈顶i = j                                # 下一层j = 2* i + 1                         # 重新设定左孩子结点else:                                    # 如果栈顶元素是最大的li[i] = temp                         # 将栈顶元素存入栈顶或者某个子树的根节点break                                # 结束循环else:li[i] = temp                             # 将原栈顶元素放在叶子结点
    

    堆排序代码:

    def heap_sort(li):n = len(li)for i in range((n-2)//2, -1, -1):            # 从叶子结点的子树向每个子树的根节点遍历change_down(li, i, n-1)                  # 建堆for i in range(n-1, -1, -1):                 # 挨个取出栈顶元素li[0], li[i] = li[i], li[0]              # 将栈顶元素和最后一个元素进行交换change_down(li, 0, i-1)                  # 向下调整

    测试用例:[2, 4, 8, 7, 3, 5]

    运行截图:

    在这里插入图片描述

    测试用例:[5, 4, 2, 8, 3, 9, 5]

    运行截图:

    在这里插入图片描述

    3.3 堆排序复杂度分析

    时间复杂度:O(nlogn)

    空间复杂度:O(1) 如果使用一个辅助列表,那就是O(n)

    结语

    俗话说得好,光说不练——假把式。一定要多练,多思考。

    想不通就先不想,先去练,多练几次就明白了。

    正如古话说得好,书读百遍其义自见!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/809.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文件名批量改名,高效将文件名里的符号进行替换删除掉,实现文件名的高效管理

在信息爆炸的时代&#xff0c;我们每天都在与大量的文件打交道。从工作文档到个人照片&#xff0c;从视频剪辑到音频录音&#xff0c;每个文件背后都承载着我们的辛勤付出和美好回忆。然而&#xff0c;随着文件数量的不断增加&#xff0c;如何高效管理这些文件成为了一个亟待解…

MongoDB安装及集成

MongoDB安装及集成 前言 MongoDB是一个开源的、面向文档的 NoSQL 数据库&#xff0c;它采用了 JSON 风格的文档来存储数据&#xff0c;而不是传统的表格形式。MongoDB在数据存储方面具有灵活性和可扩展性&#xff0c;使得它成为了当今流行的数据库之一。 MongoDB的主要特点和…

关于ERA5气压和温度垂直补偿公式的对比情况

1. 气压和温度垂直补偿对比 「谨代表给个人观点&#xff0c;杠精请自测&#xff0c;对对对&#xff0c;好好好&#xff0c;你说啥都对」。 使用2020-2022陆态网GNSS与探空站并址的48个站点实验&#xff0c;以探空站为真值&#xff0c;验证ERA5精度。怎么确定并址请看前面文章…

C++感受6-Hello World 交互版

变量、常量输入、输出、流getline() 函数读入整行输入Hello() 函数复习新定义函数 Input() 实现友好的人机交互还有 “痘痘” 为什么挤不到的分析…… 1. DRY 原则简介 上一节课&#xff0c;我们写了两版“问候”程序。第一版的最大问题是重复的内容比较多&#xff0c;每一次问…

webAssembly学习及使用rust

学习理解 webAssembly 概念知识&#xff0c;使用 API 进行 web 前端开发。 概念 是一种运行在现代网络浏览器中的新型代码&#xff0c;并且提供新的性能特性和效果。它有一种紧凑的二进制格式&#xff0c;使其能够以接近原生性能的速度运行。C/C、 C#、Rust等语言可以编译为 …

RIP小实验配置及缺省路由下发

配置如下&#xff1a; IP配置&#xff1a; IP配置完先查看RIP协议学习到的路由表&#xff0c;没有内容则代表没有开启RIP 启用RIP&#xff1a;这里的rip后跟的ID只具有本地意义&#xff0c;可以在1-65535之间随便取&#xff0c;不同路由器之间都可以取用不同的&#xff0c;为了…

上网行为管理系统功能介绍_上网行为管理实现的功能

上网行为管理系统是一种集成了网络监控、行为分析、策略管理和安全控制等功能的综合性软件解决方案。 它通过对企业内部网络的全面监控和深度分析&#xff0c;帮助管理者了解员工的网络使用习惯、识别潜在风险、优化网络资源配置&#xff0c;并最终实现网络安全和效率的双重提…

对接浦发银行支付(三)-- QR扫码付

一、使用场景 扫码付&#xff0c;指的是支付平台&#xff0c;给每个用户的具体订单生成一个QR二维码&#xff0c;用户本人或者他人扫码付款。 付款用户可以直接识别二维码&#xff0c;或者下载到本地&#xff0c;通过微信或支付宝扫一扫识别&#xff0c;第二步将跳转至对应的支…

详细分析Java中的AuthRequest类(附Demo)

目录 前言1. 基本知识2. Demo3. 实战 前言 公共接口&#xff0c;定义了对第三方平台进行授权、登录、撤销授权和刷新 token 的操作 1. 基本知识 先看源码基本API接口&#xff1a; import me.zhyd.oauth.enums.AuthResponseStatus; import me.zhyd.oauth.exception.AuthExce…

SSDReporter for Mac:全面检测SSD健康,预防数据丢失,让您的Mac运行更稳定

SSDReporter for Mac是一款专为Mac用户设计的固态硬盘&#xff08;SSD&#xff09;健康状况检测工具&#xff0c;旨在帮助用户全面了解并监控其Mac设备中SSD的工作状态&#xff0c;从而确保数据的完整性和设备的稳定性。 这款软件具有多种强大的功能。首先&#xff0c;它能够定…

09-ARM开发板的HelloWorld

在ARM开发板上运行x86_64平台程序 前面在Ubuntu系统编译生成了X86_64平台的HelloWorld程序&#xff0c;通过NFS服务器&#xff0c;尝试在开发板上直接运行。 如图所示&#xff0c;程序无法正常运行&#xff0c;终端提示ARM开发板在执行x86架构&#xff08;Intel或AMD&#xff…

c++使用googletest进行单元测试

googletest进行单元测试 使用Google test进行测试一、单元测试二、使用gmock测试 使用Google test进行测试 使用场景&#xff1a; 在平时写代码中&#xff0c;我们需要测试某个函数是否正确时可以使用Google test使用&#xff0c;当然&#xff0c;我们也可以自己写函数进行验证…

旅游陪同翻译难吗, 旅游翻译英译中哪家好?

近来&#xff0c;随着中国旅游业的蓬勃发展&#xff0c;旅游陪同翻译的需求也水涨船高&#xff0c;这些专业的翻译服务者为中外游客搭建起友谊的桥梁&#xff0c;引领他们共同探索中国这片古老而神秘的土地 。那么&#xff0c;旅游陪同翻译英译中难吗&#xff1f;我们如何在众多…

mysql数据库连接工具(mysql数据库连接工具怎么备份数据不备份表结构)

MySQLWorkbench连接,导入和导出数据库? 1、导出&#xff1a;使用MySQL Workbench连接到MySQL服务器&#xff0c;选择要导出的数据库&#xff0c;右键单击数据库并选择“导出”。选择要导出的表和数据&#xff0c;将导出文件保存为.sql文件。 2、打开MySQL Workbench&#xf…

OpenHarmony 视图缩放组件—subsampling-scale-image-view

简介 深度缩放视图&#xff0c;图像显示&#xff0c;手势平移缩放双击等 效果图&#xff08;旋转、缩放、平移&#xff09; 下载安装 ohpm install ohos/subsampling-scale-image-view OpenHarmony ohpm 环境配置等更多内容&#xff0c;请参考如何安装 OpenHarmony ohpm 包 使…

昂科烧录器支持Nuvoton新唐科技的低功耗微控制器M482SIDAE

芯片烧录行业领导者-昂科技术近日发布最新的烧录软件更新及新增支持的芯片型号列表&#xff0c;其中Nuvoton新唐科技的低功耗微控制器M482SIDAE已经被昂科的通用烧录平台AP8000所支持。 M482SIDAE以Arm Cortex-M4F为核心&#xff0c;是带有DSP指令集的高效能低功耗微控制器。其…

基于Spingboot+vue协同过滤音乐推荐管理系统

项目演示视频效果&#xff1a; 基于Spingbootvue协同过滤音乐推荐管理系统 基于Spingbootvue协同过滤音乐推荐管理系统 1、项目介绍 基于Springboot的音乐播放管理系统总共两个角色&#xff0c;用户和管理员。用户使用前端前台界面&#xff0c;管理员使用前端后台界面。 有推荐…

【Win】怎么下载m3u8视频\怎么通过F12开发人员工具获取视频地址\怎么下载完整的.ts格式视频

怎么下载m3u8视频&#xff1f;首先通过浏览器本地的开发人员工具&#xff0c;获取m3u8的地址&#xff0c;然后再通过第三方下载工具下载&#xff0c;此处以N_m3u8DL-CLI_v3.0.2为例 如下图的步骤&#xff0c;即可获取到视频的m3u8地址 打开N_m3u8DL-CLI_v3.0.2&#xff0c;粘贴…

如何实现外网访问内网ip?公网端口映射或内网映射来解决

本地搭建服务器应用&#xff0c;在局域网内可以访问&#xff0c;但在外网不能访问。如何实现外网访问内网ip&#xff1f;主要有两种方案&#xff1a;路由器端口映射和快解析内网映射。根据自己本地网络环境&#xff0c;结合是否有公网IP&#xff0c;是否有路由权限&#xff0c;…

基于Springboot的社区疫情返乡管控系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的社区疫情返乡管控系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系…