二叉树:任意一个节点子节点最多只有两个的树。
森林:n个互不相交的树的集合。
满二叉树:在不增加树的层数的情况下,无法再多增加一个节点的树称为满二叉树。
完全二叉树:1.除最后一层外,每一层上的节点数均达到最大值;2.在最后一层上只缺少右边的若干接点。
把一个普通树转化为二叉树来存储:设法保证任意一个节点的左指针域指向他的第一个孩子,右指针域指向他的兄弟,只要能满足条件,就可以把一个普通树转化为二叉树。
孩子就是指一个根下面的节点,兄弟指的是同在一个根下的节点,它们互为兄弟。
树的三种遍历方式的遍历顺序:
前序遍历:根左右
中序遍历:左根右
后序遍历:左右根
由上我们可以知道:所谓的前中后是以根在第几顺序被遍历而命名的。在后续排列中:树的根结点会是排列中的最后一个。前序遍历中,树的根结点是排列的第一个。
根据中序,后序,前序中的任意一种遍历我们都不可以得到二叉树。但是,先序和中序我们可以推导出原始二叉树。中序和后序我们可以推导出原始二叉树,先序和后序我们不可以推导出原始二叉树。