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

26 avl树(下)

#define _CRT_SECURE_NO_WARNINGS 1 #include<vector> #include"AVLTree.h" void TestAVLTree1() { AVLTree<int, int> t; // 常规的测试用例 int a[] = { 16, 3, 7, 11, 9, 26, 18, 14, 15 }; // 特殊的带有双旋场景的测试用例 //int a[] = { 4, 2, 6, 1, 3, 5, 15, 7, 16, 14 }; for (auto e : a) { t.Insert({ e, e }); } t.InOrder(); } int main() { TestAVLTree2(); return 0; }

中序没毛病

怎么检查是不是avl树

这也要套一层

就没问题。

插入logN 很快,

void InOrder() { _InOrder(_root); cout << endl; } int Height() { return _Height(_root); } int Size() { return _Size(_root); } bool IsBalanceTree() { return _IsBalanceTree(_root); } Node* Find(const K& key) { Node* cur = _root; while (cur) { if (cur->_kv.first < key) { cur = cur->_right; } else if (cur->_kv.first > key) { cur = cur->_left; } else { return cur; } } return nullptr; } private: void _InOrder(Node* root) { if (root == nullptr) { return; } _InOrder(root->_left); cout << root->_kv.first << ":" << root->_kv.second << endl; _InOrder(root->_right); } int _Height(Node* root) { if (root == nullptr) return 0; int leftHeight = _Height(root->_left); int rightHeight = _Height(root->_right); return leftHeight > rightHeight ? leftHeight + 1 : rightHeight + 1; } int _Size(Node* root) { if (root == nullptr) return 0; return _Size(root->_left) + _Size(root->_right) + 1; } bool _IsBalanceTree(Node* root) { // 空树也是AVL树 if (nullptr == root) return true; // 计算pRoot结点的平衡因子:即pRoot左右子树的高度差 int leftHeight = _Height(root->_left); int rightHeight = _Height(root->_right); int diff = rightHeight - leftHeight; // 如果计算出的平衡因子与pRoot的平衡因子不相等,或者 // pRoot平衡因子的绝对值超过1,则一定不是AVL树 if (abs(diff) >= 2) { cout << root->_kv.first << "高度差异常" << endl; return false; } if (root->_bf != diff) { cout << root->_kv.first << "平衡因子异常" << endl; return false; } // pRoot的左和右如果都是AVL树,则该树一定是AVL树 return _IsBalanceTree(root->_left) && _IsBalanceTree(root->_right); } private: Node* _root = nullptr; };

删除节点一定是左为空或者右为空,

现在是0.说明之前是1或者-1,就要往上更新

变成1 -1 不用更新,高度不变,再删10 ,就要旋转了,

http://www.gsyq.cn/news/89163.html

相关文章:

  • openvela——动态管理日志输出通道及其实现原理
  • 连接2026:十款远程控制软件真实力横评与选择指南
  • 可以把 Windows 从 C盘迁移到 SSD 吗?
  • Draco 3D压缩终极指南:如何高效处理大型3D模型文件
  • Overleaf插件定制实战指南:3分钟搞定编辑器功能优化
  • 15、Linux 系统下的邮件与即时通讯使用指南
  • javet 的使用
  • 数据分析工具对比:SPSS vs Tableau vs DataEase
  • 【OTA】自动化测试方案
  • 哪些文件夹里的文件是可以安全删除的?比如Temp、Download这些?
  • SuperDesign:在IDE中唤醒你的设计创造力
  • Stop-motion-OBJ:Blender网格序列动画导入终极指南
  • typescript - 11.高级类型
  • 20、Linux 系统软件更新与安装全攻略
  • JPA多對多關係時 JSON 序列化解决方案
  • 大作业笔记-4
  • iOS评论系统深度解析:构建高性能实时交互体验的完整指南
  • 智能文档处理系统快速上手指南
  • 2025.12.12博客
  • 认证--JSON
  • Path of Exile 2终极物品过滤器配置指南
  • Excel VBA快速入门:7天从零到精通终极指南
  • 算法系列(Algorithm)- 快速排序
  • MCP安全认证终极指南:如何在7天内从零到部署的完整实战
  • 芯岭技术XL2417U调试开发板 集成高性能2.4射频收发器 32位MCU USB2.0
  • 【深度好文】大模型微调技术详解:从原理到实践(建议收藏)
  • 开发昇腾AscendC算子
  • 5分钟掌握Chatterbox:开源语音克隆神器让每个人都能拥有专属声线
  • uni-app跨平台开发终极指南:一套代码多端运行
  • 突破创意瓶颈:BlenderMCP如何用AI重塑3D建模工作流