定义
二叉树(Binary Tree)是n(N>=0)
个结点的有限集合,该集合或者为空集(空二叉树),或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树的二叉树组成。
特点
- 每个结点最多有两棵子树 ,所以二叉树不存在度大于2的结点。注意不是只有两棵子树,而是最多有两棵。没有子树或者有一棵子树都是可以的。
- 左子树和右子树是有顺序的,次序不能颠倒。就像人的左手右手一样
- 即使树中某结点只有一棵子树,也要区分它是左子树还算右子树。
基本形态
- 空二叉树
- 只有一个根结点
- 根结点只有左子树
- 根结点只有右子树
- 根结点既有左子树又有右子树
特殊二叉树
- 斜树:所有的结点都只有左子树的二叉树叫左斜树;所有的结点都只有右子树的二叉树叫右斜树。这二者统称为斜树。线性表结构就是树的一种极其特殊的表现形式
满二叉树:二叉树的所有分支结点都存在左子树和右子树,并且所有叶子都在同一层上,这样的二叉树称为满二叉树。其特点有:
- 叶子只能出现在最下一层,否则不可能达到平衡
- 非叶子结点的度一定是2。否则就是“缺胳膊少腿”了
- 在同样深度的二叉树中,满二叉树的结点数量最多,叶子数量最多
完全二叉树:对一棵具有n个结点的二叉树按层序编号,如果编号为
i(1<=i<=n)
的结点与同样深度的满二叉树中编号为i的结点在二叉树中位置完全相同,则这棵二叉树称为完全二叉树。满二叉树一定是完全二叉树,反之不一定。其特点有:- 叶子结点只能出现在最下两层
- 最下层的叶子一定集中在左部连续位置
- 倒数二层,若有叶子结点,一定都在右部连续位置
- 如果结点度为1,则该结点只有左孩子,即不存在只有右子树的情况。
- 同样结点树的二叉树,完全二叉树的深度最小