本文绝对干货,食用时间约8分钟,建议细品!
引子
上一次我给大家介绍了什么是二叉搜索树,但是由于二叉搜索树查询效率的不稳定性,所以很少运用在实际的场景中,所以我们伟大的前人就对二叉搜索树进行了改良,发明了AVL树。
AVL树是一种自平衡二叉搜索树,因为AVL树任意节点的左右子树高度差的绝对值不超过1,所以AVL树又被称为高度平衡树。
AVL树本质上是一棵带有平衡条件的二叉搜索树,它满足二叉搜索树的基本特性,所以本次主要介绍AVL树怎么自平衡,也就是理解它的旋转过程。
二叉搜索树特性忘了的小伙伴可以看之前的文章:搞定二叉搜索树,9图足矣!同时我也将基本性质给大家再回顾一遍:
-
若它的左子树不为空,则左子树上所有节点的值均小于根节点的值。
-
若它的右子树不为空,则右子树上所有节点的值均大于根节点的值。
-
它的左、右子树也分别为二叉搜索树。
平衡条件:每个节点的左右子树的高度差的绝对值不超过1。
我们将每个节点的左右子树的高度差的绝对值又叫做平衡因子。
AVL树的旋转行为一般是在插入和删除过程中才发生的,因为插入过程中的旋转相比于删除过程的旋转而言更加简单和直观,所以我给大家图解一下AVL树的插入过程。
插入过程
最开始的时候为空树,没有任何节点,所以我们直接用数据构造一个节点插入就好了,比如第一个要插入的数据为18。