二叉堆是一种基于二叉树的特殊存储结构,它可以看成是一棵完全二叉树。常见的有最大堆又叫大顶堆、大根堆和最小堆又叫小顶堆、小根堆。在最大堆中的任何一个子树中都有父节点的值都大于子节点的值。在最小堆中的任何一个子树中父节点的值都小于子节点。
更多介绍参考维基百科
注释虽然二叉堆是基于二叉树的,但是实际中,我们经常使用数组来存储二叉堆,实现逻辑上的树形结构,其具备以下特点:
比如说使用数组存储的最大堆[100, 19, 36, 17, 3, 25, 1, 2, 7]
,它树形结构如下。
存储的值
索引
通过上面可以看出,节点17的在数组中的存储位置是3,它的左右子节点存储位置分别是2*3+1=7和2*3+2=8,它的父节点的存储位置是floor((3-1)/2)=1。这个特性在后续操作、维护堆的时候非常有用。
二叉堆最主要的两种操作,插入和删除,因为操作完成之后仍然要维持堆的特性,所以需要对堆中的部分节点进行调整,这两种操作的时间复杂度都是O(logN),下面以最大堆为例,看看堆的插入和删除操作。
插入逻辑
删除逻辑
下面看看数组[1,3,2,5,6,4]依次插入到最大堆和从最大堆删除的动画演示。
存储的值
索引
该动画仅演示从顶部删除节点,从中间节点删除逻辑类似。
注释