初阶数据结构(C语言实现)——5.3 堆的应用(1)——堆排序

ops/2025/3/15 3:12:57/

目录

  • 1 堆的应用
    • 1.1 堆排序
      • 1.1.1 思路
      • 1.1.2 代码实现
    • 1.2 建堆的时间复杂度
      • 1.2.1 向下调整
      • 1.2.1 向上调整
      • 1.2.3 结论

学习堆的应用之前,欢迎学习下堆。
这是博主之前的文章,欢迎学习交流

初阶数据结构(C语言实现)——5.2 二叉树的顺序结构及堆的实现
初阶数据结构(C语言实现)——5.1二叉树基础概念

1 堆的应用

1.1 堆排序

1.1.1 思路

堆排序即利用堆的思想来进行排序,总共分为两个步骤:

  1. 建堆
    升序:建大堆
    降序:建小堆
  2. 利用堆删除思想来进行排序
    建堆和堆删除中都用到了向下调整,因此掌握了向下调整,就可以完成堆排序。
    在这里插入图片描述

在这里插入图片描述

1.1.2 代码实现

void swap(HPDataType* p1, HPDataType* p2)
{HPDataType x = *p1;*p1 = *p2;*p2 = x;
}void AdjustUp(HPDataType* a, int child)
{int parent = (child - 1) / 2;//根据孩子位置,计算父亲位置while (child > 0)//child = 0,说明parent不存在了,已经到堆顶了{if (a[child] > a[parent]) //当孩子大小大于父亲大小的时候就交换{swap(&a[child], &a[parent]);//因为其他地方也要用到交换,封装了一个交换函数child = parent; //现在把父亲的值给孩子。parent = (child - 1) / 2;//继续计算现在节点的父亲结点,}else//孩子<=父亲 没必要往上走,直接break就行。		{break;}}
}
void AdjustDown(HPDataType* a, int n ,int parent)
{int child = parent*2+1;//根据父亲位置,计算孩子位置while (child <n)//走到没有孩子的时候,结束,{// 选出左右孩子中大的那一个if (child + 1 < n && a[child + 1] > a[child])//必须把child+1<n放前面,否则后面a[child+1]就越界了!{++child;}//交换if (a[child] > a[parent]){swap(&a[child],&a[parent]);parent = child;child = parent * 2 + 1;}else{break;}}
}
// 排升序 -- 建大堆void Heapsort(int* a, int n)//参数:数组和数据个数
{//建堆,方法1:向上调整堆 //模拟的是插入数据的过程for (int i = 1; i < n; ++i){AdjustUp(a, i);}//建堆,方法2:向下调整堆for (int i = 1; i < n; ++i){AdjustDown(a, n , i);}int end = n - 1;while (end > 0){swap(&a[end], &a [0]);AdjustDown(a, end, 0);--end;}
}

1.2 建堆的时间复杂度

1.2.1 向下调整

因为堆是完全二叉树,而满二叉树也是完全二叉树,此处为了简化使用满二叉树来证明(时间复杂度本来看的就是近似值,多几个节点不影响最终结果):

在这里插入图片描述

因此:向下建堆的时间复杂度为O(N)。

1.2.1 向上调整

在这里插入图片描述

因此向上建堆的时间复杂度是N*logn

1.2.3 结论

向下调整时间复杂度更小,更优,所以建堆使用的是向下调整


http://www.ppmy.cn/ops/165830.html

相关文章

hadoop集群配置-rsync命令

rsync主要用于备份和镜像 在100中新建文件夹 在conf中新建四个文件 输入命令&#xff1a; rsync -av conf/ roothadoop101:/opt/conf/

使用Mermaid语法绘制的C语言程序从Linux移植到Windows的流程图

以下是使用Mermaid语法绘制的C语言程序从Linux移植到Windows的流程图&#xff1a; graph TDA[开始移植] --> B[代码兼容性检查]B --> C[检查系统调用差异\nfork/exec -> CreateProcess]B --> D[检查文件路径格式\n/ vs \\]B --> E[检查依赖库兼容性\nPOSIX vs …

JVM的垃圾回收器都有哪些?

在 Java 虚拟机&#xff08;JVM&#xff09;中&#xff0c;不同的垃圾回收器采用不同的算法和策略&#xff0c;以满足不同应用场景的性能需求。以下为你详细介绍常见的 JVM 垃圾回收器&#xff1a; 新生代垃圾回收器 1. Serial 收集器 特点&#xff1a;单线程的垃圾回收器&a…

【网络安全 | 漏洞挖掘】$15,000——通过持久token获取个人身份信息(PII)

未经许可,不得转载。 文章目录 绕侧攻击应用程序发现注册流程中的异常token调查token泄露Google Dorking 登场Wayback Machine 的作用影响分析绕侧攻击应用程序 某金融服务平台提供了测试凭据,允许直接登录测试环境。主应用程序包含数百个功能和端点,因此在测试过程中花费了…

JAVA 基础语法备忘录 -

包装类&#xff0c;IO,多线程&#xff0c;网络编程&#xff0c;集合&#xff0c;https://http://gitee.com/SnailClimb/JavaGuide 包装类 用一个对象&#xff0c;把基本数据类型被包装成对象类型就是包装类 基本数据类型&#xff08;int&#xff0c;char,boolean,float,doubl…

万字技术指南STM32F103C8T6 + ESP8266-01 连接 OneNet 平台 MQTT/HTTP

此博客为一份详细的指南&#xff0c;涵盖 STM32F103C8T6 通过 ESP8266-01 连接 OneNet 平台&#xff0c;并使用 MQTT/HTTP 进行数据通信的完整流程。这份文档包括&#xff1a; OneNet 平台的介绍与功能概览在 OneNet 上创建和配置设备的方法STM32CubeIDE 的开发环境搭建ESP826…

《ECharts :不强不大,做点可视化》

“只考虑金钱的婚姻是荒谬的&#xff0c;不考虑金钱的婚姻是愚蠢的” ECharts 是一个强大的数据可视化库&#xff0c;广泛应用于前端开发中。 1. 基本使用步骤 ​引入 ECharts&#xff1a; 通过 CDN 引入&#xff1a; <script src"https://cdn.jsdelivr.net/npm/echar…

22 - 天 TCPIP 四层模型是什么?Cookie、Session、Token 之间有什么区别?从网络角度来看,用户从输入网址到网页显示,期间发生了什么?

TCP/IP 四层模型是什么&#xff1f; 应用层 功能&#xff1a;应用层是 TCP/IP 模型的最高层&#xff0c;它直接为用户提供各种网络应用服务&#xff0c;如网页浏览、文件传输、电子邮件等。此外&#xff0c;它还负责处理应用程序与网络之间的通信&#xff0c;包括数据的格式化、…