堆排序首先要了解以下几个基础概念:(如果不知道树或者二叉树是啥,建议先了解基础知识)
(1)完全二叉树
(2)大根堆、小根堆。
1 完全二叉树
定义:除了最后一层之外的其他每一层都被完全填充,并且所有结点都保持向左对齐。
则根据定义,可以得到以下两个结论:
(1)满二叉树必定是完全二叉树
(2)非满二叉树中,完全二叉树如左图所示,非完全二叉树如右图所示
2 完全二叉树来表示数组
根据完全二叉树的定义,可以用完全二叉树结构来维护数组,数组如下:
那么,完全二叉树可以这样表现:(红数字为数组下标)
从图中可以总结完全二叉树以下规律:
(1)结点的下标为i,则其左子结点的下标为2i+1;其右子结点的下标为2i+2;
(2)子结点的下标为i,则其父结点的下标为(i-1) / 2;
(3)下标为0的父结点还是其本身。
3 大/小根堆
堆可以理解为完全二叉树。但是这个完全二叉树,是有一定顺序的。可分为:大根堆和小根堆。
(1)小根堆:每个结点都不大于其子结点。
(2)大根堆:每个结点都不小于其子结点。
将上面的完全二叉树改成大/小根堆。