【数据结构与算法】 通俗易懂讲解 二叉堆实现
2021-03-15 10:35
标签:turn src 不能 代码 star img code int end oid MaxHeap是最大堆的对应的类。它包括的核心内容是"添加"和"删除",理解这两个算法,二叉堆也就基本掌握了。下面对它们进行介绍。 假设在最大堆[90,80,70,60,40,30,20,10,50]种添加85,需要执行的步骤如下: 将85添加到[90,80,70,60,40,30,20,10,50]中后,最大堆变成了[90,85,70,60,80,30,20,10,50,40]。 代码实现如下: 假设从最大堆[90,85,70,60,80,30,20,10,50,40]中删除90,需要执行的步骤如下: 从[90,85,70,60,80,30,20,10,50,40]删除90之后,最大堆变成了[85,80,70,60,40,30,20,10,50]。 注意:考虑从最大堆[90,85,70,60,80,30,20,10,50,40]中删除60,执行的步骤不能单纯的用它的字节点来替换;而必须考虑到"替换后的树仍然要是最大堆"! 精心整理 | 历史干货文章目录 码农有道,为您提供通俗易懂的技术文章,让技术变的更简单! 【数据结构与算法】 通俗易懂讲解 二叉堆实现 标签:turn src 不能 代码 star img code int end oid 原文地址:https://blog.51cto.com/15006953/2552028template
二叉堆添加元素
如上图所示,当向最大堆中添加数据时:先将数据加入到最大堆的末尾,然后尽可能把这个元素往上挪,直到挪不动为止!/* 最大堆向上调整算法(从start开始向上直到0,调整堆)
* 注:数组实现的堆,第N个节点的左孩子的索引值是(2N+1),右孩子的索引是(2N+2)。
* 参数说明:
start -- 被上调节点的起始位置(一般为数组中最后一个元素的索引)
*/
template
二叉树删除操作
如上图所示,当从最大堆中删除数据时:先删除该数据,然后用最大堆中最后一个的元素插入这个空位;接着,把这个“空位”尽量往上挪,直到剩余的数据变成一个最大堆。
最大堆删除代码实现:/* 最大堆的向下调整算法
* 注:数组实现的堆,第N个节点的左孩子的索引值是(2N+1),右孩子的索引是(2N+2)。
* 参数说明:
* start -- 被下调节点的起始位置
* end -- 截至范围(一般为数组中最后一个元素的索引)
*/
template
推荐阅读:
【福利】自己搜集的网上精品课程视频分享(上)
【数据结构与算法】 通俗易懂讲解 二叉树遍历
【数据结构与算法】 通俗易懂讲解 二叉搜索树专注服务器后台技术栈知识总结分享
欢迎关注交流共同进步
码农有道 coding
文章标题:【数据结构与算法】 通俗易懂讲解 二叉堆实现
文章链接:http://soscw.com/index.php/essay/64923.html