数据结构学习笔记 二叉树(1)

**【定义】**一棵二叉树T是一个有穷的结点集合。这个集合可以为空,若不为空,则它是由根结点和称为其左子树TL和右子树TR的两个不相交的二叉树组成。左子树和右子树还是二叉树。

树的相关术语
1.结点的度(Degree):一个结点的度是其子树的个数。
2.树的度:树的所有结点中最大的度数。
3.叶结点(Leaf):是度为0的结点;叶结点也可称为端结点。
4.父结点(Parent):有子树的结点是其子树的根结点的父结点。
5.子结点(Child):若A结点是B结点的父结点,则称B结点是A结点的子结点;子结点也称孩子结点。
6*.兄弟结点*(Sibling):具有同一父结点的各结点彼此是兄弟结点。
7.分支:树中两个相邻结点的连边称为一个分支。
8.路径和路径长度:从结点n1到nk的路径被定义为一个结点序列n1 , n2 ,… , nk ,对于1<= i <=k, ni是 ni+1的父结点。一条路径的长度为这条路径所包含的边(分支)的个数。
9. 祖先结点(Ancestor):沿树根到某一结点路径上的所有结点都是这个结点的祖先结点
10. 子孙结点(Descendant):某一结点的子树中的所有结点是这个结点的子孙。
11. 结点的层次(Level):规定根结点在1层,其它任一结点的层数是其父结点的层数加1。
12. 树的高度(Height):树中所有结点中的最大层次是这棵树的高度(也有把根定义成高度为1的) 。

二叉树五种基本形态
(1)空二叉树;
(2)只有根结点的二叉树;
(3)只有根结点和左子树TL的二叉树;
(4)只有根结点和右子树TR的二叉树;
(5)具有根结点、左子树TL和右子树TR的二叉树。

满二叉树和完全二叉树
满二叉树:在一棵二叉树中,如果所有分支结点都存在左子树和右子树,并且所有叶子节点都在同一层上

完全二叉树:如果一棵具有N个结点的二叉树的结构与满二叉树的前N个结点的结构相同,称为完全二叉树

二叉树的几个重要的性质
1.一个二叉树第 i 层的最大结点数为:2^ (i-1),i >= 1

2.深度为k的二叉树有最大结点总数为:2 ^k-1,k >= 1

3.对任何非空的二叉树 T,若n0表示叶结点的个数、n2是度为2的非叶结点个数,那么两者满足关系n0 = n2 +1。
n个结点的完全二叉树的深度为k 为 :Log2(n+1)向 上取整
证明: 设 n1 是度为1结点数, n 是总的结点数,边的个数为b
则有 n = n0+n1+n2
b = n-1
又 b = 0n0+1n1+2n2
联立得n0 = n2 + 1 得证

二叉树存储结构
顺序存储结构 对于一棵完全二叉树所有结点按照层序自顶向下,同一层自左向右顺 序编号,就得到一个节点的顺序序列

完全二叉树最适合这种存储结构
数据结构学习笔记 二叉树(1)_第1张图片在这里插入图片描述
链式存储数据结构学习笔记 二叉树(1)_第2张图片
数据结构学习笔记 二叉树(1)_第3张图片
在这里插入图片描述
数据结构学习笔记 二叉树(1)_第4张图片

你可能感兴趣的:(数据结构)