平衡二叉树

平衡二叉树

背景:平衡二叉树首先是二叉排序树。基于二叉排序树,发现树越矮查找效率越高,进而发明了二叉平衡树

因为基于查找的效率,所以提出了平衡二叉树,为了使高度降低。

平衡二叉树的定义

平衡因子(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:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值