前言
本周学习的知识主要学习了二叉树,以及几种不同的二叉树,详情如下。
一、二叉树
(一)简介
二叉树由多个节点组成,一个节点中存储父节点地址值、左右子节点地址值和节点实际存储的值,如果不存在对应的地址值,节点中对应的值就为null;
每一节点的子节点数量称为度,在二叉树中,任意一个节点的度要小于等于2。
(二)二叉查找树
二叉查找树又称为二叉排序树或者二叉搜索树,每个节点上最多有两个子节点,同时左子节点的值比当前节点的值来得小,而右节点的值比当前节点的值来得大,两者正好相反。
(三)平衡二叉树
在普通二叉树的基础上添加了左右子树高度差不超过1的条件,并且每一节点的左右节点都是一棵平衡二叉树。
1)旋转
为了维持二叉树的平衡,二叉树可以进行左旋或者右旋,若再添加一个子节点后,平衡二叉树不满足条件而数去平衡,此时二叉树需要进行旋转,从而使二叉树再次保持平衡。
左旋:若二叉树的右子节点高度大于左子节点,并且高度差大于2,此时二叉树需要进行左旋,实质就是将原先根节点右侧往左拉,原先的右子节点变成新