数据结构与算法(flutter)之堆(六)

堆(heap)是计算机科学中一类特殊的数据结构的统称。堆通常是一个可以被看做一棵树的数组对象。堆总是满足下列性质:

  • 堆中某个结点的值总是不大于不小于父结点的值;
  • 堆总是一棵完全二叉树

根结点最大的堆叫做最大堆大根堆根结点最小的堆叫做最小堆小根堆

数组实现堆

对于一个完全二叉树来说,用数组来存储是非常节省存储空间的。因为我们不需要存储指向左右子节点的指针,单纯的通过数组下标就可以找到一个节点的左右子节点和父节点。如下图所示。

对于数组中下标为 n 的节点来说, 这里的 n 从 1 开始算, 那么:

  • 左子节点的索引是 2n
  • 右子节点的索引是 2n+1
  • 父节点的索引满足 n/2

参考资料

堆排序原理及其应用场景

相关推荐
少许极端1 分钟前
算法奇妙屋(四十五)-CCPC备战之旅-1
java·开发语言·算法
无小道2 分钟前
算法——找规律
算法·规律
地平线开发者38 分钟前
目标检测的 Anchor-Free 和 NMS 到底是什么?
算法·自动驾驶
北顾笙9801 小时前
day24-数据结构力扣
数据结构·算法·leetcode
智者知已应修善业1 小时前
【51单片机独立按键控制往复流水灯启停】2023-6-13
c++·经验分享·笔记·算法·51单片机
pen-ai1 小时前
MAD(Median Absolute Deviation)详解:最稳健的尺度估计方法
人工智能·算法
無限進步D2 小时前
Java 基础算法训练
java·开发语言·算法·入门
门左有棵树2 小时前
蓝桥杯C++组算法知识点整理(考前急救)
c++·算法·蓝桥杯
历程里程碑2 小时前
二叉树---二叉树的最大深度
大数据·数据结构·算法·elasticsearch·搜索引擎·全文检索·深度优先
自我意识的多元宇宙2 小时前
树与二叉树--树的基本概念
数据结构·算法