7、非稳定排序四——堆排序

4、堆排序

过程:

  • 建立大根堆

    1. 找到最后一个非叶子节点(即 i = n/2),将它和最大的孩子节点互换(若它大于孩子,则不用换)
    2. 然后从后往前 依次遍历非叶子节点,并按要求调整
    3. 如果在遍历过程中,上面的节点因为要调整 导致下面原来弄好的堆结构被破坏了,此时在调整完上面的节点后 还要再调整下面的节点(只要调整一次上面的节点,那么下面的节点也要跟着调整)
  //将一个无序数组改造成按大根堆排布的数组void BuildMaxHeap(vector<int>& a,int size){for(int i=a.size()/2;i>=0;i--)HeapAdjust(a,i,size);}//把以i为父节点的结构调整为堆void HeapAdjust(vector<int>&a,int k,int size)//这里要写一下这个数组的范围,因为很多时候只需要让数组的前一部分建立堆的秩序,如堆排序{int x=a[k];//记录当前非叶子节点即父节点的值//k是父节点,i表示左孩子,i+1表示右孩子for(int i=2*k;i<size;i*=2){if(i+1<size&&a[i+1]>a[i])//比较左右孩子谁更大,让更大的孩子节点继续执行后序内容i++;if(x>a[i])//比较父节点和最大的孩子节点break;//若父节点更大,说明满足大根堆,直接不用调整了,退出循环else//如果孩子节点更大{a[k]=a[i];//则让这个孩子节点的值作为父节点的值k=i;//更新k值。现在聚焦这个孩子节点,下一轮就是看这个孩子节点的孩子节点了,原来的a[k]的值不断地往下传递//下一轮循环中,我们要判断原来父节点的值在向下调整之后会不会破坏下面的堆结构} }a[k]=x; }
  • 堆排序:

    1. 先构造大根堆,然后基于得到的大根堆,将 堆顶元素 和 待排序序列的最后一个元素 互换位置
    2. 交换元素过后,都要再调整之前的大根堆(没必要重新建造,调整即可)

    (需要注意的是,每轮都会确定一个元素,所以参与构建大根堆的元素数量也会少一个)

  void HeapSort(vector<int>&a, int size){BuildMaxHeap(a,size);for(int i=size-1;i>=2;--i){swap(a[0],a[size-1]);HeapAdjust(a,0,i);}}
  • 整体代码:
  #include<iostream>#include<vector>using namespace std;void HeapAdjust(vector<int>& a, int k, int size);//将一个无序数组改造成按大根堆排布的数组void BuildMaxHeap(vector<int>& a, int size){for (int i = a.size() / 2; i >= 0; i--)HeapAdjust(a, i, size);}//把以i为父节点的结构调整为堆void HeapAdjust(vector<int>& a, int k, int size)//这里要写一下这个数组的范围,因为很多时候只需要让数组的前一部分建立堆的秩序,如堆排序{int x = a[k];//记录当前非叶子节点即父节点的值//k是父节点,i表示左孩子,i+1表示右孩子for (int i = 2 * k; i < size; i *= 2){if (i + 1 < size && a[i + 1] > a[i])//比较左右孩子谁更大,让更大的孩子节点继续执行后序内容i++;if (x > a[i])//比较父节点和最大的孩子节点break;//若父节点更大,说明满足大根堆,直接不用调整了,退出循环else//如果孩子节点更大{a[k] = a[i];//则让这个孩子节点的值作为父节点的值k = i;//更新k值。现在聚焦这个孩子节点,下一轮就是看这个孩子节点的孩子节点了,原来的a[k]的值不断地往下传递//下一轮循环中,我们要判断原来父节点的值在向下调整之后会不会破坏下面的堆结构}}a[k] = x;}void HeapSort(vector<int>& a, int size){BuildMaxHeap(a, size);for (int i = size - 1; i >= 2; i--){swap(a[0], a[i]);HeapAdjust(a, 0, i);}swap(a[0], a[1]);}int main(){vector<int> nums = { 2,3,6,1,4,5,9,7,8 };HeapSort(nums, nums.size());for (int i = 0; i < nums.size(); i++){cout << nums[i] << endl;}}
  • 稳定性:因为堆排序涉及前后交换,相等元素的相对位置是不能保证的,所以不稳定

  • 时间复杂度:O(nlogn),其中 建堆:O(n),排序:O(nlogn);空间复杂度:O(1)

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

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

相关文章

基于docker-compose 部署可道云资源管理器

容器编排Explorer 容器化部署MariaDB容器化部署Redis容器化部署PHP容器化部署Nginx编排部署compose服务 var code “9861ce02-1202-405b-b419-4dddd337aaa7” GitHub官网 KodExplorer 是一款网页文件管理器。它也是一个网页代码编辑器&#xff0c;可让你直接在网页浏览器中开…

【Git】--- Git远程操作 标签管理

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; Git 前面我们学习的操作都是在本地仓库进行了&#xff0c;如果团队内多人协作都在本地仓库操作是不行的&#xff0c;此时需要新的解决方案 --- 远程仓库。…

Deepseek API+Python 测试用例一键生成与导出 V1.0.3

** 功能详解** 随着软件测试复杂度的不断提升,测试工程师需要更高效的方法来设计高覆盖率的测试用例。Deepseek API+Python 测试用例生成工具在 V1.0.3 版本中,新增了多个功能点,优化了提示词模板,并增强了对文档和接口测试用例的支持,极大提升了测试用例设计的智能化和易…

Axure RP9.0 教程:左侧菜单列表导航 ( 点击父级菜单,子菜单自动收缩或展开)【响应式的菜单导航】

文章目录 引言I 实现步骤添加商品管理菜单组推拉效果引言 应用场景:PC端管理后台页面,左侧菜单列表导航。 思路: 用到了动态面板的两个交互效果来实现:隐藏/显示切换、展开/收起元件向下I 实现步骤 添加商品管理菜单组 在左侧画布区域添加一个菜单栏矩形框;再添加一个商…

详细比较StringRedisTemplate和RedisTemplate的区别及使用方法,及解决融合使用方法

前言 感觉StringRedisTemplate和RedisTemplate非常的相识&#xff0c;到底有什么区别和联系呢&#xff1f;点开idea&#xff0c;打开其依赖关系&#xff0c;可以看出只需使用maven依赖包spring-boot-starter-data-redis&#xff0c;然后在service中注入StringRedisTemplate或者…

SpringSecurity——前后端分离登录认证

SpringSecurity——前后端分离登录认证的整个过程 前端&#xff1a; 使用Axios向后端发送请求 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>登录</title><script src"https://cdn…

如何用腾讯云建站做好一个多语言的建筑工程网站?海外用户访问量提升3倍!分享我的经验

作为新疆地区领先的工程建筑企业&#xff0c;我们深知在数字化浪潮中&#xff0c;一个专业、高效且具备国际视野的官方网站是企业形象与业务拓展的“门面担当”。然而&#xff0c;传统的建站流程复杂、技术门槛高、多语言适配难等问题&#xff0c;曾让我们在数字化转型中举步维…

遥控器钥匙学习---通过uds指令

1、实际报文 2、硬件配置信息 使用原gateway硬件&#xff0c;软件基于sbcm-main工程新建的一个分支。主要用于钥匙学习的指令发送。 3、后续更改 这里需要细化一下&#xff0c;为了后续方便测试 4、钥匙学习策略 可以学习2把钥匙 一次可以学习把钥匙&#xff0c;uds命令&…

QinQ项展 VLAN 空间

随着以太网技术在网络中的大量部署&#xff0c;利用 VLAN 对用户进行隔离和标识受到很大限制。因为 IEEE802.1Q 中定义的 VLAN Tag 域只有 12 个比特&#xff0c;仅能表示 4096 个 VLAN&#xff0c;无法满足城域以太网中标识大量用户的需求&#xff0c;于是 QinQ 技术应运而生。…

给Web开发者的HarmonyOS指南02-布局样式

给Web开发者的HarmonyOS指南02-布局样式 本系列教程适合鸿蒙 HarmonyOS 初学者&#xff0c;为那些熟悉用 HTML 与 CSS 语法的 Web 前端开发者准备的。 本系列教程会将 HTML/CSS 代码片段替换为等价的 HarmonyOS/ArkUI 代码。 布局基础对比 在Web开发中&#xff0c;我们使用CS…

mapbox进阶,添加鹰眼图控件

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️mapboxgl-minimap 鹰眼控件二、🍀添加…

Linux 配置时间服务器

一、同步阿里云服务器时间 服务端设置 1.检查chrony服务是否安装&#xff0c;设置chrony开机自启&#xff0c;查看chrony服务状态 [rootnode1-server ~]# rpm -q chrony # rpm -q 用于查看包是否安装 chrony-4.3-1.el9.x86_64 [rootnode1-server ~]# systemctl enable --n…

Android实践开发制作小猴子摘桃小游戏

Android实践制作小猴子摘桃小游戏 实践素材项目源文件获取&#xff1a;Android可以存在版本差异项目如果不能正确运行&#xff0c;可以使用里面的素材自己构建项目Android实践制作小猴子摘桃小游戏Android实践制作小猴子摘桃小游戏https://mp.weixin.qq.com/s/jNU_hVfj9xklsil…

数据库查询练习

1.单表查询 CREATE TABLE worker (部门号 int(11) NOT NULL,职工号 int(11) NOT NULL,工作时间 date NOT NULL,工资 float(8,2) NOT NULL,政治面貌 varchar(10) NOT NULL DEFAULT 群众,姓名 varchar(20) NOT NULL,出生日期 date NOT NULL,PRIMARY KEY (职工号) ) ENGINEInnoDB…

VGG 改进:添加ScConv空间与通道特征重构卷积

目录 1. ScConv空间与通道特征重构卷积 2. VGG+ScConv模块 3. 完整代码 Tips:融入模块后的网络经过测试,可以直接使用,设置好输入和输出的图片维度即可 1. ScConv空间与通道特征重构卷积 ScConv (Spatial and Channel reconstruction Convolution) 是一种旨在减少卷积神…

如何优化SQL查询以提高数据库性能?

你正在自助餐厅&#xff0c;所有的食物看起来都很美味。但你不是拿一个盘子&#xff0c;只取你需要的&#xff0c;而是开始从各个角落堆满食物&#xff0c;弄得一团糟&#xff0c;速度也慢了下来。结果是什么&#xff1f;你拿的东西很多并且效率低下。 这就像没有优化的SQL查询…

VS2022的第一个Qt程序——实战《加载并显示图像》

目录 一、UI设计 S1&#xff1a;双击Form Files下.ui文件&#xff0c;进入ui设计界面Qt Designer S2&#xff1a;然后拖动一个Push Button和Label控件到界面 S3&#xff1a;点击信号与槽&#xff0c;然后点击PushButton往外拉一下 S4&#xff1a;松开鼠标进入配置连接界面…

决策树算法详解:从西瓜分类到实战应用

目录 0. 引言 1. 决策树是什么&#xff1f; 1.1 生活中的决策树 1.2 专业版决策树 2. 如何构建决策树&#xff1f; 2.1 关键问题&#xff1a;选哪个特征先判断&#xff1f; 2.1.1 信息熵&#xff08;数据混乱度&#xff09; 2.1.2 信息增益&#xff08;划分后的整洁度提…

Python 标准库与数据结构

Python的标准库提供了丰富的内置数据结构和函数&#xff0c;使用这些工具能为我们提供一套强有力的工具。 需要注意的是&#xff0c;相比C与Java&#xff0c;Python的一些特点&#xff1a; Python不需要显式声明变量类型Python没有模板(Template)的概念&#xff0c;因为Pytho…

VUE3 路由配置

1.下载 VueRouter 模块 在命令行中输入 yarn add vue-router 2.导⼊相关函数 在自己创建的router/index.js 文件中 import { createRouter, createWebHashHistory } from vue-router 3.创建路由实例 在自己创建的router/index.js 文件中 const theFirstRouter ()>{return…