1.完全二叉树与满二叉树:
(1)满二叉树:要么是叶子结点(结点的度为0),要么结点同时具有左右子树(结点的度为2)。
(2)完全二叉树:除了最后一层以外,每层结点都完全填满,在最后一层上如果不是满的,则只缺少右边的若干结点。
(3)完美二叉树:每层结点都完全填满。
2.哈夫曼树
给定n个权值作为n个叶子结点,构造一棵二叉树,若带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。
哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近。
3.二叉查找树(Binary Search Tree),
(1)概念(又:二叉搜索树,二叉排序树)它或者是一棵空树,或者是具有下列性质的二叉树:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
它的左、右子树也分别为二叉排序树。
(2)二叉排序树有什么好处?
是一种比较有用的折衷方案。
数组的搜索比较方便,可以直接用下标,但删除或者插入某些元素就比较麻烦。
链表与之相反,删除和插入元素很快,但查找很慢。
二叉排序树就既有链表的好处,也有数组的好处。
在处理大批量的动态的数据是比较有用。
(3)存储结构:
二叉排序树通常采取二叉链表作为二叉排序树的存储结构。