0

0

c++中如何实现AVL树_c++平衡二叉树插入与旋转方法

尼克

尼克

发布时间:2026-01-14 21:59:50

|

467人浏览过

|

来源于php中文网

原创

AVL树插入后必须自底向上检查并旋转,因插入可能使某节点平衡因子变为±2;首次发现失衡节点即旋转修复,再向上递归检查。LL、RR、LR、RL四种旋转由插入路径方向决定,旋转需更新涉及节点高度并返回新根。

c++中如何实现avl树_c++平衡二叉树插入与旋转方法

AVL树插入后为什么必须检查并可能旋转

因为AVL树要求任意节点的左右子树高度差(平衡因子)绝对值 ≤ 1。单纯插入可能导致某节点平衡因子变为 ±2,此时必须通过旋转恢复平衡。关键不是“插完再统一调整”,而是从插入点向上回溯到根,**首次发现失衡节点就立即旋转修复**,之后其父节点高度变化可能引发更高层失衡,需继续向上检查。

四种旋转场景怎么判断和选择

失衡节点记为 node,插入发生在它的子树中。旋转类型由插入路径的“方向组合”决定:

  • LL:插入发生在 node->left->left —— 右旋 node
  • RR:插入发生在 node->right->right —— 左旋 node
  • LR:插入发生在 node->left->right —— 先对 node->left 左旋,再对 node 右旋
  • RL:插入发生在 node->right->left —— 先对 node->right 右旋,再对 node 左旋

实际编码中,通常用平衡因子(height(node->right) - height(node->left))和插入后子树高度变化方向联合判断,避免重复遍历。

旋转操作本身要改哪些指针

旋转本质是局部子树重构,只修改涉及的 3–4 个节点的 left/right 指针,不改变键值。以右旋为例(LL):

立即学习C++免费学习笔记(深入)”;

Node* rotateRight(Node* y) {
    Node* x = y->left;
    Node* T2 = x->right;
x->right = y;
y->left = T2;

// 更新高度(假设 height() 是成员函数或辅助函数)
y->height = max(height(y->left), height(y->right)) + 1;
x->height = max(height(x->left), height(x->right)) + 1;

return x;

}

萝卜简历
萝卜简历

免费在线AI简历制作工具,帮助求职者轻松完成简历制作。

下载

注意:T2 非空时,它原属于 x 的右子树,旋转后成为 y 的左子树;所有旋转都必须更新参与节点的高度,否则后续平衡因子计算错误。

插入函数里如何嵌入平衡维护逻辑

标准递归插入返回新子树根,每层返回前检查当前节点是否失衡,并执行对应旋转。典型结构如下:

Node* insert(Node* node, int key) {
    // 1. 标准BST插入
    if (!node) return new Node(key);
    if (key < node->key)
        node->left = insert(node->left, key);
    else if (key > node->key)
        node->right = insert(node->right, key);
    else
        return node; // 重复键,不插入
// 2. 更新当前节点高度
node->height = 1 + max(height(node->left), height(node->right));

// 3. 计算平衡因子
int bf = getBalanceFactor(node);

// 4. 四种失衡情况处理(返回旋转后的新根)
if (bf > 1 && key < node->left->key)     // LL
    return rotateRight(node);
if (bf < -1 && key > node->right->key)   // RR
    return rotateLeft(node);
if (bf > 1 && key > node->left->key)     // LR
    return rotateLeftRight(node);
if (bf < -1 && key < node->right->key)   // RL
    return rotateRightLeft(node);

return node; // 无需旋转,返回原节点

}

容易忽略的点:旋转后必须返回新根(如 rotateRight 返回 x),否则父节点的指针会指向被“转下去”的旧根,导致树断裂;另外,getBalanceFactor 必须用 height(right) - height(left),符号反了会导致 LL/RR 判断颠倒。

相关专题

更多
C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

55

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.8万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 19万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号