AVL树的左旋右旋理解
来源:互联网 发布:麻将软件开发 编辑:程序博客网 时间:2024/04/30 13:42
AVL树是最先发明的自平衡二叉查找树。在AVL树中任何节点的两个子树的高度最大差别为一,所以它也被称为高度平衡树。查找、插入和删除在平均和最坏情况下都是O(log n)。增加和删除可能需要通过一次或多次树旋转来重新平衡这个树。AVL树得名于它的发明者G.M. Adelson-Velsky和E.M. Landis,他们在1962年的论文《An algorithm for the organization of information》中发表了它。
节点的平衡因子是它的左子树的高度减去它的右子树的高度(有时相反)。带有平衡因子1、0或 -1的节点被认为是平衡的。带有平衡因子 -2或2的节点被认为是不平衡的,并需要重新平衡这个树。平衡因子可以直接存储在每个节点中,或从可能存储在节点中的子树高度计算出来。
AVL树的基本操作一般涉及运作同在不平衡的二叉查找树所运作的同样的算法。但是要进行预先或随后做一次或多次所谓的"AVL旋转"。
以上内容转自维基百科AVL树
从图中可以比较形象的看出所谓左旋右旋的旋转支点是三个主节点中大小居中的那个节点,左旋就是左边的节点降下来,右旋就是右边的节点降下来,都成为中间节点的子树。
左右双旋分解就是先将左侧节点降为左子树,右边节点将为右子树。当然中间有合并子树的过程,这里没有细说。
高度为h的AVL树,节点数N最多; 最少 ( 其中 )N是h的斐波那契数列。
- AVL树的左旋右旋理解
- AVL树 封装左旋 右旋操作
- avl树左旋右旋的理解
- 二叉树的左旋和右旋
- 树的左旋与右旋
- 二叉树的左旋和右旋
- 树的左旋与右旋
- 树的左旋和右旋
- 红黑树的理解与学习&左旋与右旋操作
- 序列的左旋右旋
- 字符串的左旋右旋
- AVL的左旋右旋,看完秒懂。稍后补上代码。
- 平衡二叉树(AVL树)一图一步骤代码实现左旋右旋,左右平衡操作
- nyoj202 红黑树 (二叉树的左旋右旋)
- 红黑树的插入创建(左旋 右旋)
- 字符串的左旋和右旋
- 左旋右旋字符串
- 左旋(右旋)字符串
- ACdream群原创群赛(3)
- Bash 4.1条件正则表达式与3.1的改变之处
- Opencv2.3 图像特征检测总结
- 展讯(SPRD)WRE学习-1
- sed用法
- AVL树的左旋右旋理解
- POJ 1321 棋盘问题
- iPhone开发【十三】动画效果之最简单的动画——动态加载图片
- for的死循环(逗号表达式)
- linux 解压缩 命令
- 学习OpenCV——初始化视频第一帧 .
- Linux查看CPU和内存使用情况
- poj 1160
- foj 1493 基础baby-step-giant-step