传说中的另一棵树
堆
一种特殊的树。
基本概念
堆需要满足的两个要求:
- 堆是一个完全二叉树
- 堆中每一个节点的值都必须大于等于(或小于等于)其子树中每个节点的值。
大顶堆:节点的值大于等于子树中节点的值
小顶堆:节点的值小于等于字数中节点的值
大顶堆
|
小顶堆
|
堆的实现
因为堆是完全二叉树,用数组来存储比较方便。
节点下标为i
,则左子节点下标为2*i
,右子节点下标为2*i+1
,父节点下标为i/2
。
插入
堆中插入新数据后,需要满足堆的两个特性。调整的过程叫做“堆化”。
堆化分为两种:从上往下、从下往上。
思路:顺着节点所在的路径,向上,对比,