平衡二叉树
背景:平衡二叉树首先是二叉排序树。基于二叉排序树,发现树越矮查找效率越高,进而发明了二叉平衡树
因为基于查找的效率,所以提出了平衡二叉树,为了使高度降低。
平衡二叉树的定义
平衡因子(BF Balance factor):BF(T)=hL-hR,其中hL和hR分别为T的左、右子树的高度。
平衡二叉树(Balanced Binary Tree)(AVL树):空树或者任一结点左、右子树高度差的绝对值不超过1,即|BF(T)<=1|。
平衡二叉树的调整
调整之后保证仍然是搜索树
从离插入结点最近的结点调整
四种调整:RR,LL,RL,LR
RR:左旋转
LL:右旋转
RL:先右后左
LR:先左后右
RR旋转
定义:
“麻烦结点(BR的孩子)”在“发现者(A)”右子树的右边,因而叫RR插入,需要RR旋转。
代码
typedef struct TreeNode* AVLTree;
struct TreeNode
{
int data;
AVLTree left;
AVLTree right;
};
AVLTree RR(AVLTree A) {
AVLTree B = A->right;
A->right = B->left;
B->left = A;
return B;
}
LL旋转
定义:
“麻烦结点(BL的孩子)”在“发现者(A)”左子树的左边,因而叫LL插入,需要LL旋转。
代码
AVLTree LL(AVLTree A) {
AVLTree B = A->left;
A->left = B->right;
B->right = A;
return B;//新的根结点
}
LR旋转
定义:
“麻烦结点(CL或者CR或者两者的孩子)”在"发现结点(A)"的左子树的右边,因而叫LR插入,需要LR旋转。
RL旋转
定义:
“麻烦结点(CL或者CR或者两者的孩子)”在"发现结点(A)"的右子树的左边,因而叫LR插入,需要LR旋转。
练习1:
: