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

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

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

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

数组实现堆

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

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

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

参考资料

堆排序原理及其应用场景

相关推荐
zsc_1181 分钟前
pvz3解码小游戏求解算法 (二)
算法
hanbr9 分钟前
每日一题day1(Leetcode 76最小覆盖子串)
算法·leetcode
AI科技星10 分钟前
张祥前统一场论中两个电荷定义的统一性解析
开发语言·线性代数·算法·数学建模·平面
代码地平线11 分钟前
C语言实现堆与堆排序详解:从零手写到TopK算法及时间复杂度证明
c语言·开发语言·算法
小江的记录本11 分钟前
【大语言模型】大语言模型——核心概念(预训练、SFT监督微调、RLHF/RLAIF对齐、Token、Embedding、上下文窗口)
java·人工智能·后端·python·算法·语言模型·自然语言处理
炘爚13 分钟前
LeetCode(两两交换链表中的节点)
算法·leetcode·链表
wsoz13 分钟前
Leetcode矩阵-day7
c++·算法·leetcode·矩阵
念越13 分钟前
算法每日一题 Day01|双指针解决移动零问题
java·算法·力扣
不想看见40414 分钟前
Merge k Sorted Lists 优先队列--力扣101算法题解笔记
笔记·算法·leetcode
_深海凉_16 分钟前
LeetCode热题100-合并区间
算法·leetcode·职场和发展