树是n(n≥0)个结点的有效集合,n=0时,称为空树,这是一种特殊情况。在任意一颗非空树中应该满足:
void preOrder(TreeNode *R){
if(R!=NULL){
visit(R);//访问根节点
while(R还有下一个子树T){
preOrder(T);//先根遍历下一颗子树
}
}
}
void postOrder(TreeNode *R){
if(R!=NULL){
while(R还有下一个子树T){
preOrder(T);//先根遍历下一颗子树
}
visit(R);//访问根节点
}
}
森林。是m(m≥0)棵互不相干的树的集合。每棵树去掉根节点后,其各个子树又组成森林
先序遍历森林:若森林为非空,则按如下规则进行遍历:
效果等同于依次对各个树进行先根遍历
若森林为非空,则按如下规则进行遍历:
效果等同于依次对各个树进行后根遍历