胜者树是一种数据结构,特点如下:
- 它是一棵完全二叉树。也就是说,除最后一层外,每一层上的节点数均达到最大值;在最后一层上只缺少右边的若干结点。
- 这棵树的所有叶子结点是原始数据(见下文样例)。
- 对于所有非叶子结点,取两个儿子中更优秀的值,就是父亲结点的值,故名胜者树。
- 由于胜者树是完全二叉树,因此如果把根结点编号为1,第二层的结点分别是2、3,第三层是4、5、6、7……那么我们就能发现:每一个非叶子结点的左儿子编号都是它的编号乘以2,右儿子编号是它的编号乘以2加上1。
如上图,我们有原始数列a={4,2,9,1},两两比对,优秀者成为更高层的结点。可知根结点的值就是原始数据中最优秀的值。容易推算,建树的时间复杂度仅为O(n)。程序如下:
void build_tree ( int _left , int _right , int _node ) { if ( _left == _right ) tree[_node].value = a[_left] ; else { int _middle = ( _left + _right