目录
树只是数据之间的逻辑关系的形象表示,而不是一种存储方式,所以其存储方式合理即可。
关于树的基本概念
根
度:结点拥有的子树,称为该结点的度。
子树:
结点
结点的分类
叶节点:度为0的结点。
分支结点度不为0的结点。
结点间的关系
孩子:
兄弟:同一个双亲的孩子。
结点的祖先
结点的层次
树的深度或高度
有序树
无序树
森林
树在内存中的表示
内存单元是线性的,所有树在内存中的存储无法直接反映逻辑关系。
双亲表示法
data | parent |
---|
孩子表示法
data | firstchild | firstchild |
---|
多重链表
*双亲孩子表示法:
data | parent | firstchild |
---|
孩子兄弟表示法
data | firstchild | rightsib |
---|
特殊的树:二叉树
定义
特点
- 每个结点最多存在两棵子树。
- 左子树和右子树是有顺序的,不可颠倒。即使某节点只有一颗子树,也要区分是左子树还是右子树。
五种基本形态
- 空二叉树
- 只有一个根结点
- 根结点只有左子树
- 根结点只有右子树
- 根结点既有左子树,又有右子树。
特殊的二叉树
斜树
又分为
左斜数:
右斜树:
满二叉树
定义:所有分支节点都存在左子树和右子树,并且所有叶子都在同一层。
特点:
(1)叶子只能出现在最下一层。
(2)非叶子结点的度为2。
(3)在同样深度的二叉树中,满二叉树的结点个数最多,叶子数最多。
完全二叉树
编号是连续的。就好像满二叉树从后往前一个个剔除一样。
特点:
- 叶子节点只能出现在最下两层。
- 最下层的叶子节点一定集中在左部连续位置。
- 倒数第二层,若没有叶子结点,一定都在右部连续位置。
- 如果结点度为1,则该结点只有左孩子。
- 同样结点数的二叉树,完全二叉树的深度最小。
二叉树的性质
- 在二叉树第 i 层上至多有2i-1个结点。
- 深度为k的二叉树至多有2k-1个结点。
- 对于任何一颗二叉树,如果其终端结点数为n0,度为2的结点数为n2,则n0 = n2 + 1。
- 具有n个结点的完全二叉树的深度为 log2n」+1
二叉树在内存中的表示
顺序存储结构
- 完全二叉树
- 一般二叉树
在用顺序存储结构对一般二叉树进行表示是还会存在内存空间的浪费,所以这种方法不太适合表示非完全二叉树。
二叉树相较于普通树,其优越性在此得以体现。
二叉链表
lchild | data | rchild |
---|
也可以拓展到三叉树。
二叉树的遍历
定义: 从根结点出发,按照某次序依次访问二叉树中所有结点,使得每个结点被访问一次且仅被访问一次。
遍历顺序最重要。
前序遍历
中序遍历
后序遍历
从左到右,先子叶后结点,最后访问根结点。
层序遍历
从根结点开始访问,从上而下逐层遍历,在同一层中,按从左到右的顺序对结点逐个访问。
二叉树的建立
线索二叉树
树、森林与二叉树的转化
赫夫曼树及其应用
赫夫曼树的定义和定理
赫夫曼编码