博客
关于我
平衡二叉树(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/

    你可能感兴趣的文章
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>
    OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
    查看>>
    oauth2登录认证之SpringSecurity源码分析
    查看>>
    OAuth2:项目演示-模拟微信授权登录京东
    查看>>
    OA系统多少钱?OA办公系统中的价格选型
    查看>>
    OA系统选型:选择好的工作流引擎
    查看>>
    OA让企业业务流程管理科学有“据”
    查看>>
    OA项目之我的会议(会议排座&送审)
    查看>>