博客
关于我
平衡二叉树(AVL)
阅读量:593 次
发布时间:2019-03-11

本文共 939 字,大约阅读时间需要 3 分钟。

平衡二叉树(Balanced Binary Search Tree,简称AVL树)是由Adelson-Velskii和Landis于1962年提出的,用于保持二叉排序树的高度较低,减少IO操作时间等关键性性能指标的影响。

定义

平衡二叉树是一个二叉排序树,满足以下条件:

  • 左右子树的深度之差的绝对值不超过1;
  • 左右子树本身也都是平衡二叉树。
  • 每个节点的平衡因子(Balance Factor,BF)定义为左子树深度减去右子树深度,取值范围为-1、0、1。平衡因子绝对值超过1时,该节点的子树即为失衡。

    平衡二叉树算法思想

    当在平衡二叉树中插入或删除节点时,可能导致平衡性破坏。此时需要:

  • 找到插入或删除导致破坏平衡的最小子树,记其根节点为P;
  • 通过旋转调整该子树,使其重新成为平衡子树。
  • 失去平衡的最小子树是插入或删除节点后导致平衡因子绝对值达到2的根节点及其子树的范围。

    平衡旋转操作

    各类型旋转操作如下:

    1. LL型旋转

    在P节点的左孩子左子树插入节点,或P节点的左孩子右子树删除节点后导致P的平衡因子变为2。此时:

    • 将P的左孩子B向右上旋转成为新的根节点;
    • P原为B的左子树,向左下旋转成为B的新右子树。

    2. RR型旋转

    在P节点的右孩子右子树插入节点,或右孩子左子树删除节点后导致P的平衡因子变为-2。此时:

    • 将P的右孩子C向左上旋转成为新的根节点;
    • P原为C的右子树,向右下旋转成为C的新左子树。

    3. LR型旋转

    在P节点的左孩子右子树插入节点后,使P的平衡因子变为2。此时:

    • 先将P的左孩子B的右子树根节点D向左上旋转(逆时针旋转),使其成为B的新左子树;
    • 再将B向右上旋转,使D成为新的根节点,P原左子树旋转为B的新右子树。

    4. RL型旋转

    在P节点的右孩子左子树插入节点后,使P的平衡因子变为-2。此时:

    • 先将P的右孩子C的左子树根节点D向右上旋转(顺时针旋转),使其成为C的新右子树;
    • 再将C向左上旋转,使D成为新的根节点,P原右子树旋转为C的新左子树。

    这些旋转操作保证了在插入或删除节点后,平衡子树始终保持高度平衡,确保了整体树的性能优势。

    平衡二叉树通过旋转操作(3-4次最多一次)调整局部失衡,保持整体平衡,从而实现高效操作和较低的时间复杂度。

    转载地址:http://nlctz.baihongyu.com/

    你可能感兴趣的文章
    phoenixframework集成了所有自动化测试的思想的平台。mark一下。
    查看>>
    phoenix_执行sql报错_Error: ERROR 504 (42703): Undefined column. columnName=(state=4270_大数据工作笔记0181
    查看>>
    phoenix启动失败_The history file `/root/.sqlline/history` may be an older history---记录024_大数据工作笔记0184
    查看>>
    Phoenix基础命令_视图映射和表映射_数字存储问题---大数据之Hbase工作笔记0036
    查看>>
    phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
    查看>>
    Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
    查看>>
    phoenix连接hbase报错Can not resolve hadoop120, please check your network_记录026---大数据工作笔记0187
    查看>>
    PhotoPrism:这款获得35.8K星的AI照片管理神器你值得拥有
    查看>>
    Photoshop工作笔记001---Photoshop常用快捷键总结
    查看>>
    photoshop智能参考线
    查看>>
    Reids配置文件redis.conf中文详解
    查看>>
    Photoshop脚本入门
    查看>>
    PHP
    查看>>
    Regular Expression Notes
    查看>>
    PHP $FILES error码对应错误信息
    查看>>
    PHP $_FILES函数详解
    查看>>
    PHP $_SERVER['HTTP_REFERER'] 获取前一页面的 URL 地址
    查看>>
    php & 和 & (主要是url 问题)
    查看>>
    php -- 魔术方法 之 判断属性是否存在或为空:__isset()
    查看>>
    php -- 魔术方法 之 获取属性:__get()
    查看>>