排序算法 --- 堆排序

根据大顶堆的描述, 父节点的值始终大于子节点(如果有的话)的值, 再加上堆是完全二叉树, 可以用数组表示, 那么就可以用来进行排序.

具体做法就是, 对于随机排列的数组:

1. 首先将其构建成一个大顶堆, 根据堆的性质, 此时堆顶就是最大值.

2. 把堆顶元素与数组最后一个元素进行交换, 也就是把最大值换至最后一个元素

3. 把元素个数减一, 重复上述两个步骤

可以看出最复杂的, 也就是构造大顶堆的过程, 对于一个随机排列的数组, 其构建大顶堆的步骤如下:

假设有一个数组A, 共有n(14)个元素(如图).

1. 首次构建时, 需要遍历所有的子树, 让所有的子树满足大顶堆性质, 而只有一个节点的子树则不需要遍历(因为不需要调整), 所以要从第一个非叶子节点的子树开始遍历, 构建大顶堆. 而第一个非叶子节点的子树根节点, 在数组中的下标为 n / 2 - 1(也就是6, 目前6不需要调整), 从此开始一直至0(注意当上层树发生变化时, 需要递归调整下层的树, 为什么要从下至上调整, 因为下层调整完成后, 已经把下层最大的调整至根节点了, 这样当根节点发生变化时, 只需要从上向下再调整一遍, 因为下层已经不可能有比上面更大的值了).

例子中的步骤为:

1. 首先遍历第一个非叶子节点, 14 / 2 - 1 = 6, 发现不用调整, 然后遍历5, 发现也不用调整, 然后遍历4, 交换4 9的值:

 2. 遍历3, 交换3 8:

3.  遍历2, 不用动, 遍历1, 交换1 3, 然后发现68交换到3后, 3 7 8子树不需要动(就算需要动, 也不需要再动1 3 4了, 因为之前3 7 8已经调整过, 新上来的不可能取代已经上去的了):

4. 遍历0, 交换0 1, 交换1 3, :

 

(3 7 8不再需要调整, 原因同上一步)

2. 首次构建完大顶堆后, 交换首个元素与最后一个元素的值, 然后重新构建大顶堆

1. 交换0 13:

2. 数组长度少一:

3. 从根节点开始重新构建大顶堆, 交换0 2,  交换2 5:

4. 这样又重新构建成了大顶堆, 重复上述步骤

代码:

leetcode链接(第912题): https://leetcode-cn.com/problems/sort-an-array/submissions/

(第215题)

void heapify(vector<int>& nums, int root, int max_index) {int left = 2 * root + 1;if (left > max_index)return;int right = 2 * root + 2;int exchange_index = left;if (right <= max_index && nums[right] > nums[left])exchange_index = right;if (nums[root] < nums[exchange_index]) {swap(nums[root], nums[exchange_index]);heapify(nums, exchange_index, max_index);}
}
vector<int> sortArray(vector<int>& nums) {int total = nums.size();for (int i = total / 2 - 1; i >= 0; i --) {heapify(nums, i, total - 1);}int target_index = total - 1;while (target_index > 0) {swap(nums[0], nums[target_index]);target_index --;heapify(nums, 0, target_index);}return nums;
}

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

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

相关文章

数据结构中的树 --- 红黑树

红黑树是一种几近平衡的二叉搜索树, 但不是AVL树. 1 红黑树的一些特殊性质 1. 每个节点皆为红色或者黑色。 2. 根节点是黑色。 3. 每个叶子节点&#xff08;NIL&#xff09;是黑色(注意, 每个叶子节点必须都为空节点, 也就是指针为nullptr, 无key值)。 4. 每个红色结点的两…

c++数据结构中 顺序队列的队首队尾_数据结构与算法—队列详解

前言栈和队列是一对好兄弟&#xff0c;前面我们介绍过数据结构与算法—栈详解&#xff0c;那么栈的机制相对简单&#xff0c;后入先出&#xff0c;就像进入一个狭小的山洞&#xff0c;山洞只有一个出口&#xff0c;只能后进先出(在外面的先出去)。而队列就好比是一个隧道&#…

phpstudy apache无法启动_phpstudy和wamp哪个好

刚刚接触php的同学会想知道phpstudy和wamp的区别有哪些&#xff1f;phpstudy和wamp哪个好&#xff1f;下面我们来总结一下。一&#xff1a;phpstudy好还是wamp好php的运行环境配置对于新手都是一件比较困难的事情&#xff0c;但是对于高手配置是一件繁琐的事情&#xff0c;个人…

哈夫曼树(最优二叉树)

1 用途 现在假如有一个需求, 把一个很长的字符串用二进制编码的形式存储, 要尽可能的占用较小空间, 那么应该怎么存储呢. 肯定是要确定每个字母的编码方法, 比如 001是A, 010是B等. 那么要怎么确定每个字符编成什么二进制码从而使得总长度最短? 一个根本思想是, 出现频率高的…

visual studio无法更新_VS Code Python 扩展 5 月更新

(给Python编程开发加星标&#xff0c;提升编程技能.)12 号&#xff0c;微软在官方博客发布了 VS Code 编辑器中 Python 扩展的 5 月更新&#xff0c;其中只有一个较为重要的特性&#xff1a;新增了浏览选择 Python 解释器的能力。增加这个功能&#xff0c;主要是为了让选择或变…

至强cpu型号列表_装机必看——CPU型号参数详解

装机必看——CPU型号参数详解——装机个人练习生-海在初步解了电脑构成后&#xff0c;我们DIY装机首先要看的就是如何选CPU&#xff0c;今天就带大家详细学习CPU的各类数据。说到CPU&#xff0c;我们先来介绍下生产CPU的两大公司——Intel和AMD。这两家公司相爱相杀接近50年了&…

多路平衡查找树 --- B(B-)树

1 简介 可以用阶数来描述B树, 一棵M阶B树代表着该B树最多有M个孩子节点. 如果M为2, 那么该B树就是一棵二叉搜索树. 一棵M阶B树具有以下性质: 1. 每个节点最多有M - 1个关键字. 跟普通的树不同, B树的关键字有多个. 2. 根节点最少可以只有一个关键字. 3. 非根节点至少有k个关…

B+树操作方式

1 简介 B树与B树相似, 也存在不同. 可以理解为把所有元素都放在叶子节点, 索引B树化的树. B树的一些性质: 1. B树的节点分类: 内部节点(索引节点), 叶子节点. 如果只有根节点有元素, 那么其可以是内部节点也可以是叶子节点. 2. B树与B树最大的不同是内部节点不保存数据, 只…

java执行查询postgresql得到中文乱码_比这个夏天还要热的PostgreSQL数据库来啦!

什么是PostgreSQL&#xff1f;云数据库 PostgreSQL 是京东云基于开源的 PostgreSQL 10.6 版本构建的一款功能强大的企业级关系型数据库管理系统。PostgreSQL有“世界上可获得的最先进的开源数据库”之称&#xff0c;在过去20年的飞速发展中&#xff0c;该数据库已经广泛应用在G…

python按列读取txt文件_如何使用pandas读取txt文件中指定的列(有无标题)

最近在倒腾一个txt文件&#xff0c;因为文件太大&#xff0c;所以给切割成了好几个小的文件&#xff0c;只有第一个文件有标题&#xff0c;从第二个开始就没有标题了。 我的需求是取出指定的列的数据&#xff0c;踩了些坑给研究出来了。 import pandas as pd # 我们的需求是 取…

jpa多表关联查询_Spring Boot 整合mybatis如何自定义 mapper 实现多表关联查询

上一篇文章已经介绍了自定义 mapper 实现自定义的方法&#xff0c;其实实现了通过自定义的mapper就可以做多表关联等复杂查询。但是很多朋友还是反馈说没有实现多表关联查询&#xff0c;所以&#xff0c;今天把文章又重新修改了&#xff0c;增加了多表关联的实现步骤。Mybatis …

spark on yarn 完全分布式_「大数据」(七十一)Spark之架构介绍

【导读&#xff1a;数据是二十一世纪的石油&#xff0c;蕴含巨大价值&#xff0c;这是情报通大数据技术系列第[71]篇文章&#xff0c;欢迎阅读和收藏】1 基本概念Spark 架构采用了分布式计算中的 Master-Slave 模型。 Master 是对应集群中的含有 Master 进程的节点&#xff0c;…

计算机网络数据链路层 --- 停止等待协议

停止等待协议的意义 除了比特出差错&#xff0c;底层信道还会出现丢包问题。为了实现流量控制。 停止等待协议的前提 虽然现在常用全双工通信方式&#xff0c;但为了讨论问题方便&#xff0c;仅考虑一方发送数据&#xff08;发送方&#xff09;&#xff0c;一方接收数据&…

python import如何使用_python之import引用

关于python的import引用的最大关键是init.py文件的作用&#xff0c;这个文件对于import的方法使用至关重要。这个是我在搭建自动化框架过程中用到的import的方法使用。 比如说&#xff0c;我现在login.py想引用bottom底下的log.py的时候&#xff0c;这个时候&#xff0c;我们如…

计算机网络数据链路层 --- 后退n帧协议(GBN)

滑动窗口 发送窗口 发送方维持一组连续的允许发送的帧的序号 接收窗口 接收方维持一组连续的允许接收帧的序号 发送过程 如图&#xff0c;假如发送方的发送窗口大小是6&#xff0c;首先发送0号帧&#xff0c;并建立0号帧的副本&#xff0c;防止帧丢失&#xff0c;然后发送…

简要描述内部连接和外部连接之间的区别_创新性的M12推拉式连接器推拉标准—跨制造商自动化技术的里程碑...

“八家知名制造商 – 菲尼克斯&#xff0c;浩亭&#xff0c;莫仕&#xff0c;穆尔电子&#xff0c;宾德&#xff0c;康耐&#xff0c;艾查和魏德米勒因建立M12推拉式连接器的推拉锁紧机制而在市场上确立了地位。我们共同追求一个目标&#xff0c;即确保各个制造商之间的兼容性。…

计算机网络数据链路层 --- 选择重传协议(SR)

引言 GBN协议的弊端 累计确认&#xff0c;从而导致某一帧错误后会批量重传。 可行的解决方案 可以只重传出错的帧&#xff0c;设置单个确认&#xff0c;同时加大接收窗口&#xff0c;设置接收缓存&#xff0c;缓存乱序到达的帧。这也就是选择重传协议SR。 SR中的滑动窗口 …

requests 返回的cookies为空_爬虫学习(2)(requests库)

POST请求import requestsdata {name: cxc, age: 18} r requests.post("http://httpbin.org/post", datadata) print(r.text)POST请求这样就成功地获得了返回结果&#xff0c;form部分就是提交的数据&#xff0c;证明POST请求成功发送了。响应之前我们使用了text和c…

计算机网络 --- 数据链路层介质访问控制

引言 传输数据使用的两种链路&#xff1a; 点对点链路&#xff1a;两个相邻的节点通过一个链路相连&#xff0c;没有第三者。应用&#xff1a;PPP协议&#xff0c;常用于广域网。广播式链路&#xff1a;所有主机共享通信介质。应用&#xff1a;早期的总线以太网&#xff0c;无…

6-7 使用函数输出水仙花数_学习C语言居然对printf函数不理解???

对于C语言的printf函数&#xff0c;可以说是我们学习C语言第一个接触到的函数了。printf命令的作用是格式化输出函数&#xff0c;一般用于向标准输出设备按规定格式输出信息。printf()函数的调用格式为&#xff1a;printf("", )。printf()是C语言标准库函数&#xff…