当前位置: 首页 > article >正文

数据结构【AVL树】

AVL树

  • 1.AVL树
    • 1.AVL的概念
    • 2.平衡因子
  • 2.AVl树的实现
    • 2.1AVL树的结构
    • 2.2AVL树的插入
    • 2.3 旋转
      • 2.3.1 旋转的原则

1.AVL树

1.AVL的概念

AVL树可以是一个空树。
它的左右子树都是AVL树,且左右子树的高度差的绝对值不超过1。AVL树是一颗高度平衡搜索二叉树,通过控制高度差去控制平衡。
AVL树整体结点数量和分布和完全二叉树类似,高度可以控制在 logN ,那么增删查改的效率也可以控制在O(logN ) ,相比二叉搜索树有了本质的提升。

2.平衡因子

结点的平衡因子=右子树的高度减去左子树的高度,也就是说任何结点的平衡因子等于0/1/-1,AVL树并不是必须要平衡因子,但是有了平衡因子可以更方便我们去进行观察和控制树是否平衡,就像⼀个风向标一样。
为什么AVL树是高度平衡搜索二叉树,要求高度差不超过1,而不是高度差是0呢?
因为例如二和四个结点无法达到0.

2.AVl树的实现

2.1AVL树的结构

template<class K, class V>
struct AVLTreeNode
{// 需要parent指针,后续更新平衡因⼦可以看到pair<K, V> _kv;AVLTreeNode<K, V>* _left;AVLTreeNode<K, V>* _right;AVLTreeNode<K, V>* _parent;int _bf; // balance factorAVLTreeNode(const pair<K, V>& kv):_kv(kv), _left(nullptr), _right(nullptr), _parent(nullptr), _bf(0){}
};
template<class K, class V>
class AVLTree
{typedef AVLTreeNode<K, V> Node;
public://...
private:Node * _root = nullptr;
};

2.2AVL树的插入

bool Insert(const pair<K, V>& kv)
{if (_root == nullptr){_root = new Node(kv);return true;}Node* parent = nullptr;Node* cur = _root;while (cur){if (cur->_kv.first < kv.first){parent = cur;cur = cur->_right;}else if (cur->_kv.first > kv.first){parent = cur;cur = cur->_left;}else{return false;}}cur = new Node(kv);if (parent->_kv.first < kv.first){parent->_right = cur;}else{parent->_left = cur;}cur->_parent = parent;// 更新平衡因⼦while (parent){// 更新平衡因⼦if (cur == parent->_left)parent->_bf--;elseparent->_bf++;if (parent->_bf == 0){// 更新结束break;}else if (parent->_bf == 1 || parent->_bf == -1){// 继续往上更新cur = parent;parent = parent->_parent;}else if (parent->_bf == 2 || parent->_bf == -2){// 不平衡了,旋转处理break;}else{assert(false);}}return true;
}

2.3 旋转

2.3.1 旋转的原则

保持搜索树的规则
让旋转的树从不满足变平衡,其次降低旋转树的高度
旋转总共分为四种,左单旋/右单旋/左右双旋/右左双旋。

http://www.lryc.cn/news/2378399.html

相关文章:

  • C#将1GB大图裁剪为8张图片
  • 数据库——SQL约束窗口函数介绍
  • Linux系统启动相关:vmlinux、vmlinuz、zImage,和initrd 、 initramfs,以及SystemV 和 SystemD
  • JSP链接MySQL8.0(Eclipse+Tomcat9.0+MySQL8.0)
  • Python爬虫-爬取百度指数之人群兴趣分布数据,进行数据分析
  • SEO长尾词与关键词优化实战
  • 机器学习-人与机器生数据的区分模型测试-数据处理1
  • HelloWorld
  • 令牌桶和漏桶算法使用场景解析
  • 轻量、优雅、高扩展的事件驱动框架——Hibiscus-Signal
  • SEO 优化实战:ZKmall模板商城的 B2C商城的 URL 重构与结构化数据
  • 2020CCPC河南省赛题解
  • 数字万用表与指针万用表使用方法及注意事项
  • 虚拟主播肖像权保护,数字时代的法律博弈
  • 【读代码】端到端多模态语言模型Ultravox深度解析
  • RabbitMQ工作流程及使用方法
  • Java 面向对象进阶:解锁多态、内部类与包管理
  • 算法:分治法
  • MySQL初阶:sql事务和索引
  • docker部署第一个Go项目
  • day27 python 装饰器
  • Visual Studio2022跨平台Avalonia开发搭建
  • css iconfont图标样式修改,js 点击后更改样式
  • 开源项目实战学习之YOLO11:12.4 ultralytics-models-sam-memory_attention.py源码分析
  • 【沉浸式求职学习day42】【算法题:滑动窗口】
  • LIIGO ❤️ RUST 12 YEARS
  • Linux基础开发工具二(gcc/g++,自动化构建makefile)
  • Linux zip、unzip 压缩和解压
  • muduo库TcpConnection模块详解——C++
  • Node.js 源码架构详解