数据结构之堆的实现

首先我们要想堆应该用什么实现,我们这里可以使用数组,因为每一层的数是有限个的,所以我们可以很容易将数的每一个位置对应到数组中去。

那我们就可以仿照顺序表写出我们的结构。

然后我们要考虑我们要实现哪些函数。

最基本的功能初始化和销毁,不再赘述。

然后我们实现打印

然后我们实现经典的功能入堆。

重点保证空间足够。然后我们通过Adjustup去维护大,小根堆的堆放。(此处实现的是大根堆)

将其与父节点比较,然后进行移动,直至合适位置。

然后我们实现判断是否为空和显示堆顶元素。

然后就是本贴的最后的功能,出堆。

将最后一个元素移动到堆顶,然后再进行下放,维护大根堆。

综上就是全部内容。

相关推荐
仰泳的熊猫8 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
啊哦呃咦唔鱼9 小时前
LeetCode hot100-15 三数之和
数据结构·算法·leetcode
leluckys9 小时前
算法-链表-二、成对交换两个节点
数据结构·算法·链表
随意起个昵称12 小时前
【贪心】选择尽量多的不相交区间
数据结构·算法
章小幽12 小时前
LeetCode-35.搜索插入位置
数据结构·算法·leetcode
j_xxx404_12 小时前
C++算法:一维/二维前缀和算法模板题
开发语言·数据结构·c++·算法
Book思议-14 小时前
顺序表和链表核心差异与优缺点详解
java·数据结构·链表
whn197715 小时前
在sqllog中排查达梦阻塞会话
数据结构
01二进制代码漫游日记15 小时前
C/C++中的内存区域划分
c语言·jvm·数据结构·学习
xiaoye-duck16 小时前
《算法题讲解指南:优选算法-链表》--51.两数相加,52.两两交换链表中的节点
数据结构·算法·链表