二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下。因此,两位俄罗斯的数学家G.M.Adelson-Velskii和E.M.Landis在1962年发明了一种解决上述问题的方法:当向二叉搜索树中插入新结点后,如果能保证每个结点的左右子树高度之差的绝对值不超过1(需要对树中的结点进行调整),即可降低树的高度,从而淘汰平均搜索长度。AVL树是由BST二叉搜索树改进而来,基本概念参考BST篇,本篇文章不再具体描述.
一棵AVL树大概是空树,大概是具有以下性质的二叉搜索树:
如果一棵二叉搜索树是高度平衡的,它就是AVL树。如果它有n个结点,其高度可保持在$O(log_2 n)$,搜索时间复杂度O($log_2 n$)。
- 它的左右子树都是AVL树
- 左右子树高度之差(简称平衡因子)的绝对值不超过1(-1/0/1)
(默认平衡因子=右子树高度-左子树高度)
不可能是2或-2变成1或-1,因为这是AVL树的插入,至少先保证是AVL树才能插入
左左:较高的子树是左孩子(60)所在子树,插到左孩子(60)的左子树上(c)引发根(30)旋转的情况叫“左左”。同理,水平镜像翻转的AVL子树也同理
顺口:插在较高左子树的左孩子上。
其中插入b子树使30结点发生旋转的情况:a为x/y/z,b为z,c为x/y/z,总共3*3=9种4种旋转操方法与特性
其中插入c子树使30结点发生旋转的情况:a为x/y/z,b为x/y/z,c为z,总共3*3=9种
特例的数量非常多,无法穷举。
儿子上位 -- 儿子当根
右单旋(主角是儿子):老爹在我的右上方,让老爹以我为轴,旋转到我的右下方
孙子上位 --- 孙子当根
感性描述:先左单旋再右单旋(孙子是主角):我在孙子左边,我的老爹在孙子右边,然后让孙子的爹(我)左旋下来,孙子成为我的爹,我的旧爹成为孙子的爹;末了再让孙子的新爹右旋下来。
描述2: 两次旋转分别用途: 1. 转化成标准单旋; 2.标准单旋
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) | Powered by Discuz! X3.4 |