二叉树(Binary Tree)
- 为什么要有二叉树
二叉树结合了有序数据,链表两者的优势,在树种查找数据的素的和有序数组中一样快,插入数据和删除数据的速度和链表一样快
树的概念
- 节点、根节点、父节点、子节点、兄弟节点
- 节点高度:子树的个数
- 树的高度:所有节点度中最大值
- 叶子节点:度为0的节点
- 非叶子节点:度不为0的节点
- 层数:根节点在第一层,开始计算
- 节点的深度:从根节点到当前节点的唯一路径上的节点数量
- 节点的高度:从当前节点到最远叶子节点的路径上的节点总数
- 树的深度:所有节点深度中的最大值
- 树的高度:等于树的深度
- 有序树:树中任意接待你的子节点之间有顺序关系
- 无序树:树中任意节点的子节点之间没有顺序关系,自由树
- 森林:互不相交的树
- 度:表示节点的子树du或直接继承者的数目,2度是两个孩子,或者左和右子树有两个叉树,最大度数为2。
二叉树特点
- 每个节点的度最大为2
- 左子树和右子树是有顺序的,但是没有严格的要求从大到小还是从小到大
- 二叉树是有序树
二叉树性质
- 非空二叉树的第i层,最多有2^(i-1)个节点(i>=1)
- 在高度为h的二叉树上最多有2^(h)-1 个节点(h>=1)
- 真二叉树
- 所有节点的度都为0或者2
- 满二叉树
- 全满,最后一层节点度都为0,其他节点度都为2
- 完全二叉树
- 对节点从上到下,从左到右、一层一层编号
二叉树的遍历
- 遍历是数据结构中的常见操作
- 把所有元素都访问一边
- 根据节点访问顺序的不同,二叉树的遍历方式有4种:
例如节点是:7,4,2,1,3,5,9,8,11,10,12- 前序遍历
- 7,4,2,1,3,5,9,8,11,10,12
- 用于树形结构展示
- 中序遍历
- 1、2、3、4、5、7、8、9、10、11、1
- 12、11、10、9、8 、7、5、4、3、2、1
- 二叉搜索树的中序遍历按升序或者降序处理节点
- 后序遍历
- 1、3、2、5、4、8、10、12、11、9、7
- 用于先子后父的操作
- 层序遍历
- 7、4、9、2、5、8、11、1、3、10、12
- 计算二叉树的高度
- 判断一棵树是否为完全二叉树
- 前序遍历
二叉搜索树(Binary Search Tree)
二叉搜索树的特点
- 二叉树的一种,应用非常广泛
- 又被称为二叉查找树,二叉排序树
- 任意一个节点的值都大于其左子树所有节点的值
- 任意一个节点的值都小于其右子树所有节点的值
- 二叉搜索树可以大大提高搜索数据的效率
- 存储的元素必须具备可比较性,比如int,double
- 如果是自定义类型,需要制定比较方式
- 不允许为null
平衡二叉搜索树(balanced binary search tree)
平衡二叉搜索树的特性
- 平衡:当节点数量固定时,左右子树的高度越接近,这颗二叉树就越平衡
- 经典平衡二叉搜索树,也称作自平衡二叉搜索树
- AVL树
- 红黑树
- Java中的 TreeMap、TreeSet、HashMap、HashSet
- Linux虚拟内存
AVL树
AVL树的特性
- 平衡因子:某节点的左右子树的高度差
- 平衡因子的高度差在-1~1之间
- 每个节点的左右子树高度差不超过1
- 搜索添加删除的时间复杂度是O(logN)