Java数据结构之 树(Tree)
1. 二叉查找树(Binary Search Tree)
性质:
1)若左子树不为空,则左子树上所有节点的值均小于它的根节点的值;
2)若右子树不为空,则右子树上所有节点的值均大于它的跟几点的值;
3)左右子树也分别为二叉查找树;
4)没有键值相同的节点(因此,插入的时候一定是叶子节点);
注: 插入有序节点时,退化成单支树;查找效率最好O(nlogn),最坏O(n);查找效率和插入效率相同(直插入叶子节点);删除效率最好O(logn)+O(1)->只有左子树或者只有右子树,删除效率最差O(logn)+O(logn)->左右子树同时存在;新插入的节点总是叶子节点!
2. 平衡二叉树
首先平衡二叉树是一棵二叉查找树,满足二叉查找树的所有性质。其次,它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是平衡二叉树。这个方案很好地解决了二叉查找树退化成链表的问题。这样把插入,查找,删除的时间控制在了O(logn)左右的时间。严格遵守平衡二叉树性质的是AVL树,平衡二叉树大部分操作与二叉查找树类似,主要不同在于插入删除的时候平衡二叉树的平衡可能被改变。
调整平衡:找出最小的不平衡二叉树(距离插入节点最近且左右子树高度相差大于1的节点作为根的子树),利用旋转重新调整平衡性。
3. 红黑树
红黑树也是一棵二叉查找树,并且是一棵平衡二叉树(弱平衡)。与AVL树不同,红黑树并不是严格遵守平衡二叉树的定义,在增加或者删除节点的时候,根据不同情况,AVL树旋转的次数比红黑树更多,所以红黑树用非严格的平衡来换取增删节点旋转次数的降低。
特点:在二叉查找树的基础上红黑树有如下属性
1)每个节点或者是黑色或者是红色;
2)根节点是黑色;
3)每个叶子节点是黑色(这里的叶子节点,指的是为空Null的叶子节点);
4)如果一个节点是红色的,那么他的子节点必须是黑色;
5)从一个节点到该节点的子孙外部节点的所有路径上包含相同数目的黑节点;
由性质5我们可以得知,红黑树最大路径长度不超过最短路径长度的2倍:
最长:根(黑)->红->黑->...黑(叶子节点) 红色穿插
最短:根(黑)->黑->黑->...黑(叶子节点) 全是黑色
查找代价:基本维持在O(logn)左右,但最差情况下(最长是最短的2倍)比AVL树略差;
插入代价:RBT插入需要旋转操作和变色操作。由于只需要保持RBT基本平衡,因此插入节点最多只需要旋转2次;