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

    你可能感兴趣的文章
    nginx + etcd 动态负载均衡实践(二)—— 组件安装
    查看>>
    nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
    查看>>
    Nginx + Spring Boot 实现负载均衡
    查看>>
    Nginx + uWSGI + Flask + Vhost
    查看>>
    Nginx - Header详解
    查看>>
    Nginx - 反向代理、负载均衡、动静分离、底层原理(案例实战分析)
    查看>>
    nginx 1.24.0 安装nginx最新稳定版
    查看>>
    nginx 301 永久重定向
    查看>>
    nginx css,js合并插件,淘宝nginx合并js,css插件
    查看>>
    Nginx gateway集群和动态网关
    查看>>
    Nginx Location配置总结
    查看>>
    Nginx log文件写入失败?log文件权限设置问题
    查看>>
    Nginx Lua install
    查看>>
    nginx net::ERR_ABORTED 403 (Forbidden)
    查看>>
    Nginx SSL私有证书自签,且反代80端口
    查看>>
    Nginx upstream性能优化
    查看>>
    Nginx 中解决跨域问题
    查看>>
    nginx 代理解决跨域
    查看>>
    Nginx 动静分离与负载均衡的实现
    查看>>
    Nginx 反向代理 MinIO 及 ruoyi-vue-pro 配置 MinIO 详解
    查看>>