文章目录
一、树(Tree)
树是n个结点的有限集。
(1)特点:
- 由且仅有一个特定的称为根(Root)的结点。
- 当n>1时,其余结点可以分为m个互不相交的有限集,其中每一个集合本身又是一棵树(子树(SubTree))。
(2)度、深度、森林等概念
-
结点拥有的子树数称为结点的度(Degree),度为0的结点称为叶结点(Leaf)或终端结点,度不为0的非终端结点或分支结点。除根结点之外,分支结点也称为内结点。
- -
树的度:是树内各结点的度的最大值,
-
树的深度:树中结点的最大层次称为树的深度(Depth)或高度
-
若将树中结点的各子树看成是从左向右是有次序的,不能互换,则称树为有序树,否则为无序树
-
森林(Forest)是m棵互不相交的树的集合
二、二叉树(Binary Tree)
(1)定义:
n个结点的有限集合,该集合或者为空集,或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树的二叉树组成。
(2)特点:
- 每个结点最多有两棵子树。所以二叉树的度<=2
- 左子树和右子树是有顺序的,次序不能颠倒
- 即使树中某结点只有一棵子树,也要区分它是左子树还是右子树。(就是左偏还是右偏,如图)
1.几种特殊的二叉树
1.斜树
所有的结点都只有左子树的二叉树叫左斜树。反之为右斜树。这两种统称为斜树
2.满二叉树
若所有分支结点都存在左子树和右子树,并且所有叶子都在同一层上。
特点:叶子只能出现最下一层;非叶子结点的度一定是2;在深度相同的二叉树中,满二叉树的结点个数最多,叶子数最多。
3.完全二叉树
满二叉树一定是一棵完全二叉树,反之不一定。
(1)定义:
对于一棵具有n个结点的二叉树按层编号,若编号为i的结点与同样深度的满二叉树中编号i的结点在二叉树中的位置相同。
(1)特点:
- 叶子结点=只能出现在最下两层。
- 最下层的叶子一定集中在左部连续位置。
- 倒数第二层,若有叶子结点,一定都在右部连续位置。
- 若结点的度为1,则该结点只有左孩子,即不存在只有右子树的情况。
- 同样结点数的二叉树,完全二叉树的深度最小。
(2)判断是否为完全二叉树的方法:
给每个结点按照满二叉树的结构逐层顺序编号,若编号出现空挡,就说明不是二叉树,否则就是。(6,7没有,但是往下继续编号的时候要从8开始)
2.二叉树的性质
-
性质1:在二叉树的第i层至多有2i-1个结点。
-
性质2:深度为k的二叉树至多有2k-1个结点。
-
性质3:对任何一棵二叉树T,若其终端结点数为N0,度为2的结点数为N2,则N0=N2+1
-
性质4:具有n个结点的完全二叉树的深度为[log2n]+1([x]表示不大于x的最大整数)
-
性质5:若对一棵有n个结点的完全二叉树(深度有性质4可得)的结点安层编号(从1层往下,每层从左到右),对任一结点:
1.若i=1,则结点i是根,无双亲;若i>1,则其双亲是结点[i/2]
2.若2i>n,则结点i无左孩子(结点i为叶子结点);否则其左孩子是结点2i
3.若2i+1>n,则结点i无右孩子;否则其右孩子是结点2i+1
3.二叉树的存储结构
(1)顺序存储结构
顺序存储结构一般只用于完全二叉树(下标就按照满二叉树的编号来,对于没有的结点用^)
(2)链式存储结构
二叉树的链式存储结构叫二叉链表。
每个结点有一个数据域和两个指针域,如图:
lchild为指向左孩子的指针,rchild为指向右孩子的指针。
三、二叉树的遍历
(1)定义:
从根结点触发,按照某种次序依次访问二叉树中的所有结点,使得每个结点被访问一次且仅一次。
(2)二叉树遍历的性质:
1.已知前序遍历序列和中序遍历序列,可以唯一确定一棵二叉树。
2.已知后序遍历序列和中序遍历序列,可以唯一确定一棵二叉树。
3.已知前序和后序遍历序列,不能确定一棵二叉树。
4.但扩展二叉树(每个结点的空指针引出值为#的虚结点)可以只用一个遍历序列确定二叉树
1.前序遍历
先打印,再递归左和右
规则:先访问根结点,然后前序遍历左子树,再前序遍历右子树。遍历顺序为:ABDGHCEIF
2.中序遍历
先递归左,再打印,最后递归右
规则:从根结点开始(不是先访问根结点),中序遍历根结点的左子树,然后访问根结点,最后中序遍历右子树,遍历顺序为:GDHBAEICF
3.后序遍历
先递归左右,再打印
规则:从左到右先叶子后结点的方式遍历访问左右子树,最后访问根结点,遍历顺序为:GHDBIEFCA
4.层序遍历
从树的第一层开始(即根结点),从上而下遍历,同一层从左向右。遍历顺序为:ABCDEFGHI