0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C语言排序中堆排序的技巧

C语言编程学习基地 来源:C语言编程学习基地 作者:C语言编程学习基地 2021-07-29 15:29 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

堆是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。

对于堆的操作通常需要以下3个步骤:

最大堆调整(Max Heapify):将堆的末端子节点作调整,使得子节点永远小于父节点

创建最大堆(Build Max Heap):将堆中的所有数据重新排序

堆排序(HeapSort):移除位在第一个数据的根节点,并做最大堆调整的递归运算。

C代码实现

920e4226-edfd-11eb-a97a-12bb97331649.png

代码看起来比较抽象,将代码运行时数据交换的过程打印出来,然后结合二叉树的图形来分析,就会比较好理解了。代码运行过程中数据交换过程如下:

923d3004-edfd-11eb-a97a-12bb97331649.png

为了方便观看这里使用二叉树图形生成软件,通过二叉树图形来观察数据交换过程。二叉树图形生成使用的是一个在线生成网站:mshang.ca/syntree 后面所有的二叉树图形都使用此软件生成。

代码一开始首先打印出原始数据

数组元素 0 8 1 5 4 3 7 9 2 6 将这10个数据在网站上使用公式生成二叉树的图表,软件界面如下:

93a8ed3e-edfd-11eb-a97a-12bb97331649.png

首先将数组从上至下按顺序排列,转换成二叉树。

公式:0[8 [5 9[2]][4[6]]] [1[3] [7 ]]]

转换成二叉树之后,需要让这个无序堆变成最大堆,也就是每个堆都实现父节点的值大于任何一个子节点值。从最后一个堆开始,依次比较父节点和子节点的值,如果子节点值大于父节点值,就需要交换。

9435a3b4-edfd-11eb-a97a-12bb97331649.png

创建最大堆: 6为最后一个子节点,所以从6开始依次和父节点比较,如果子节点大于父节点,就需要交换子节点和父节点的位置。从设备树图形中可以看出,子节点6大于父节点4,所以需要交换子节点的父节点的位置。

公式:0[8 [5 9[2]][6[4]]] [1[3] [7 ]]]

交换 6 和4

6交换完成后,接下来依次向前比较其他子节点,6前面的节点是2,2小于父节点5,继续向前查找子节点9,子节点9大于父节点5,所以就交换9和5的位置。

公式:0[8 [9 5[2]][6[4]]] [1[3] [7 ]]]

交换9和5

接下来继续向前查找,发现子节点7大于父节点1,继续交换。

公式:0[8 [9 5[2]][6[4]]] [7[3] [1 ]]]

交换7和1

继续向前查找发现子节点9大于父节点8,交换位置。

公式:0[9 [8 5[2]][6[4]]] [7[3] [1 ]]]

交换9和8

继续比较其他节点

公式:9[0 [8 5[2]][6[4]]] [7[3] [1 ]]]

交换9和0

公式:9[8 [0 5[2]][6[4]]] [7[3] [1 ]]]

交换8和0

公式:9[8 [5 0[2]][6[4]]] [7[3] [1 ]]]

交换5和0

此时最大堆已经创建完成,此时根节点的数字9就是数组中的最大值。

代码中打印出来的数据顺序和通过二叉树图形分析出来的顺序完全一样。此时最大堆调整已经完成了。接下来就需要开始堆排序,依次将根节点的数据存放到最后一个节点,形成一个有序堆。

9592b544-edfd-11eb-a97a-12bb97331649.png

堆排序(最大堆调整)

首先交换数组中第一个元素,和排序好的前一个元素位置。此时数组中的第一个元素是9,排序完成之后最后一个元素是4,交换9和4.

95afbbda-edfd-11eb-a97a-12bb97331649.png

公式:4[8 [5 0[2]][6[9]]] [7[3] [1 ]]]

交换9和4

交换完成后,此时最大值9所在的底部位置就成为了有序区,有序区之后就不会参与任何对比。接下来继续调整父节点和子节点,确保父节点要大于子节点。

公式:8[4 [5 0[2]][6[9]]] [7[3] [1 ]]]

交换8和4

公式:8[6 [5 0[2]][4[9]]] [7[3] [1 ]]]

交换6和4

此时数字8称为了根节点,是目前无序区中的最大值,将8和底部区的2交换,将当前最大值8放到有序区中。

公式:2[6 [5 0[8]][4[9]]] [7[3] [1 ]]]

交换8和2

此时8已经存放到了有序区中,此后就不参与任何交换了。此时2变为根节点后,需要在重新调整一次节点,确保父节点大于子节点。

公式:7[6 [5 0[8]][4[9]]] [2[3] [1 ]]]

交换7和2

公式:7[6 [5 0[8]][4[9]]] [3[2] [1 ]]]

交换3和2

此时数字7变为根节点,是无序区间的最大值。需要将根节点的数字移动到有序区中。

将根节点7和0交换位置。

公式:0[6 [5 7[8]][4[9]]] [3[2] [1 ]]]

交换7和0

接下来重新调整节点 公式:6[0 [5 7[8]][4[9]]] [3[2] [1 ]]]

交换6和0

公式:6[5 [0 7[8]][4[9]]] [3[2] [1 ]]]

交换5和0

此时6变为了根节点,是无序区间的最大值。

将根节点和有序区间的前一个数字交换,也就是1和6需要交换。

公式:1[5 [0 7[8]][4[9]]] [3[2] [6 ]]]

交换6和1

接下来重新调节一次节点

公式:5[1 [0 7[8]][4[9]]] [3[2] [6 ]]]

交换5和1

公式:5[4 [0 7[8]][1[9]]] [3[2] [6 ]]]

交换4和1

此时5变成的根节点,需要将5移动到有序队列中去。

接下来需要交换根节点5和无序节点2的位置

公式:2[4 [0 7[8]][1[9]]] [3[5] [6 ]]]

交换5和2

重新调整节点位置

公式:4[2 [0 7[8]][1[9]]] [3[5] [6 ]]]

交换4和2

此时4是无序列表中的最大值,需要交换4和1的位置

公式:1[2 [0 7[8]][4[9]]] [3[5] [6 ]]]

交换4和1

重新调整节点位置

公式:9[2 [0 6[7]][3[8]]] [1[4] [5 ]]]

交换3和1

此时3为无序列表中最大值,需要交换3和0的位置。

公式:0[2 [3 7[8]][4[9]]] [1[5] [6 ]]]

交换3和0

交换完成后重新调整节点位置 公式:9[0 [2 6[7]][3[8]]] [1[4] [5 ]]]

交换2和0

此时2变成了无序列表中最大值,1为有序列表的前一个值,交换2和1的位置。

公式:1[0 [3 7[8]][4[9]]] [2[5] [6 ]]]

交换2和1

此时1是根节点,无序列表中就剩0一个数字了,交换1和0。

公式:0[1 [3 7[8]][4[9]]] [2[5] [6 ]]]

9a890706-edfd-11eb-a97a-12bb97331649.png

交换1和0

这是0变成了根节点,而其他的所有数字都在有序列表中,无序列表中已经没有数字了,此时说明排序完成。

9acd8d9a-edfd-11eb-a97a-12bb97331649.png

可以看出最好、最坏、一般情况下数据移动的次数和方法基本都差不多。

接下来随机生成10000个数据,看看排序需要多长时间。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • C语言
    +关注

    关注

    183

    文章

    7646

    浏览量

    146126

原文标题:【数据结构】C语言排序方法——堆排序详解!

文章出处:【微信号:cyuyanxuexi,微信公众号:C语言编程学习基地】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    MAX16050/MAX16051:电压监测与排序电路的理想选择

    MAX16050/MAX16051:电压监测与排序电路的理想选择 在电子设计领域,对于电压监测和电源排序的需求日益增长,特别是在服务器、工作站、网络系统等复杂设备。今天,我们就来深入探讨
    的头像 发表于 03-02 09:15 150次阅读

    深入解析 LTC2923:电源跟踪与排序的理想解决方案

    深入解析 LTC2923:电源跟踪与排序的理想解决方案 在电子设备的设计,电源的跟踪和排序至关重要,它直接影响着设备的性能和稳定性。LTC2923 作为一款强大的电源跟踪控制器,为我们提供了简单
    的头像 发表于 02-28 15:35 280次阅读

    ADM6819/ADM6820:简单电源排序器的技术剖析与应用指南

    ADM6819/ADM6820:简单电源排序器的技术剖析与应用指南 在电子设备的设计,电源排序对于确保系统的稳定运行至关重要。ADM6819和ADM6820作为具有FET驱动能力的简单电源
    的头像 发表于 02-28 14:25 256次阅读

    ADM1066:多功能电源监控与排序芯片的深度解析

    ADM1066:多功能电源监控与排序芯片的深度解析 在电子设备的设计,电源的监控与排序是确保系统稳定运行的关键环节。ADM1066作为一款功能强大的电源监控与排序芯片,为多电源系统提
    的头像 发表于 02-28 14:05 199次阅读

    ADM1068:多功能电源监控与排序芯片的深度解析

    ADM1068:多功能电源监控与排序芯片的深度解析 在电子系统设计,电源的监控与排序至关重要,它直接关系到系统的稳定性和可靠性。今天,我们就来深入探讨一款功能强大的电源监控与排序芯片
    的头像 发表于 02-28 14:05 207次阅读

    LTC2937:六通道电源排序器与电压监控器的设计与应用

    LTC2937:六通道电源排序器与电压监控器的设计与应用 在电子系统设计,电源管理是至关重要的一环。合理的电源排序和电压监控能够确保系统的稳定运行,避免因电源问题导致的故障和损坏。今天,我们就来
    的头像 发表于 02-28 11:15 300次阅读

    ADM1169:多电源系统的监控与排序解决方案

    ADM1169:多电源系统的监控与排序解决方案 在电子工程师的日常工作,多电源系统的监控与排序是一个关键且复杂的问题。今天要为大家介绍的Analog Devices的ADM1169 Super
    的头像 发表于 02-28 11:10 270次阅读

    ADM1166:多电源系统监控与排序的理想解决方案

    ADM1166:多电源系统监控与排序的理想解决方案 在多电源系统的设计,对电源的监控和排序是至关重要的环节。ADM1166作为一款可配置的监控/排序设备,为多电源系统的电源监控和
    的头像 发表于 02-28 11:10 299次阅读

    探索LM3880:三轨简单电源排序器的卓越性能与应用

    探索LM3880:三轨简单电源排序器的卓越性能与应用 在电子设计领域,电源管理是一个至关重要的环节。今天,我们将深入探讨德州仪器(TI)推出的LM3880三轨简单电源排序器,它为多电压轨的电源排序
    的头像 发表于 02-26 17:20 618次阅读

    深度解析TPS38700S-Q1:多通道电源排序器的卓越之选

    深度解析TPS38700S-Q1:多通道电源排序器的卓越之选 在电子设计领域,电源管理和排序对于确保系统的稳定运行至关重要。特别是在复杂的系统,如先进驾驶辅助系统(ADAS)、汽车摄像头模块
    的头像 发表于 02-26 16:20 187次阅读

    TPS38700:多通道电源排序器的技术剖析与应用指南

    TPS38700:多通道电源排序器的技术剖析与应用指南 在电子设备的设计,电源管理是至关重要的一环。多通道电源排序器能够精确控制多个电源的开启和关闭顺序,确保设备的稳定运行。今天,我们就来深入
    的头像 发表于 02-26 15:55 183次阅读

    MAX16050/MAX16051:具备反向排序功能的电压监控与排序电路

    MAX16050/MAX16051:具备反向排序功能的电压监控与排序电路 在电子系统设计,对电源电压的精确监控和有序控制至关重要。Maxim Integrated推出的MAX16050
    的头像 发表于 01-31 17:15 926次阅读

    C语言插入排序算法和代码

    是,将元素逐个添加到已经排序好的数组中去,同时要求,插入的元素必须在正确的位置,这样原来排序好的数组是仍然有序的。   在实际使用,通常是排序整个无序数组,所以把这个无序数组分为两
    发表于 01-15 06:44

    光纤线芯都是按照什么颜色排序

    多次有朋友留言问到,光纤熔接颜色如何排序,这个在实际应用还是比较多的,那么今天我们就不讲原理了,直接用图文简单明了讲光纤熔接色谱,大家可以了解下。 一、常规排序 1、4芯的排序:蓝、
    的头像 发表于 12-19 11:02 2180次阅读

    低成本电源排序器解决方案

    绝大多数负载点DC-DC转换器可以将上一个转换器的电源就绪输出连接至下一个转换器的使能输入,实现上电排序。这种方法只适合比较简单的设计,不能满足多数现代微处理器和DSP的要求一这类器件要求断电顺序必须与上电顺序相反。许多厂商针对这类应用推出了可编程排序IC,但器件价格较为
    的头像 发表于 05-21 09:55 1292次阅读
    低成本电源<b class='flag-5'>排序</b>器解决方案