遍历二叉树
2007-09-23 01:28
176 查看
一、复习二叉树的定义
二叉树由三个基本单元组成:根结点、左子树、右子树
问题:如何不重复地访问二叉树中每一个结点?
二、遍历二叉树的三种方法:
先序 1 访问根结点
2 先序访问左子树
3 先序访问右子树
中序 1 中序访问左子树
2 中序访问根结点
3 中序访问右子树
后序 1 后序访问左子树
2 后序访问右子树
3 访问根结点
三、递归法遍历二叉树
先序:
Status(PreOrderTraverse(BiTree T,Status(*Visit)(TElemType e)){
if(T){
if(Visit(T->data))
if(PreOrderTraverse(t->lchild,Visit))
if(PreOrderTraverse(T->rchild,Visit)) return OK;
return ERROR;
}else return OK;
}
遍历结果:1,2,4,5,6,7,3
四、非递归法遍历二叉树
中序一:
Status InorderTraverse(BiTree T,Status(*Visit)(TElemType e)){
InitStack(S)ush(S,T);
while(!StackEmpty(S)){
while(GetTop(S,p)&&p)Push(S,p->lchild);
Pop(S,p);
if(!StackEmpty(S)){
Pop(S,p); if(!Visit(p->data)) return ERROR;
Push(S,p->rchild);
}
}
return OK;
}
中序二:
Status InorderTraverse(BiTree T,Status(*Visit)(TElemType e)){
InitStack(S);p=T;
while(p||!StackEmpty(S)){
if(p){Push(S,p);p=p->lchild;}
else{
Pop(S,p); if(!Visit(p->data)) return ERROR;
p=p->rchild);
}//else
}//while
return OK;
}
五、总结
二叉树遍历的意义
二叉树由三个基本单元组成:根结点、左子树、右子树
问题:如何不重复地访问二叉树中每一个结点?
二、遍历二叉树的三种方法:
先序 1 访问根结点
2 先序访问左子树
3 先序访问右子树
中序 1 中序访问左子树
2 中序访问根结点
3 中序访问右子树
后序 1 后序访问左子树
2 后序访问右子树
3 访问根结点
三、递归法遍历二叉树
先序:
Status(PreOrderTraverse(BiTree T,Status(*Visit)(TElemType e)){
if(T){
if(Visit(T->data))
if(PreOrderTraverse(t->lchild,Visit))
if(PreOrderTraverse(T->rchild,Visit)) return OK;
return ERROR;
}else return OK;
}
遍历结果:1,2,4,5,6,7,3
四、非递归法遍历二叉树
中序一:
Status InorderTraverse(BiTree T,Status(*Visit)(TElemType e)){
InitStack(S)ush(S,T);
while(!StackEmpty(S)){
while(GetTop(S,p)&&p)Push(S,p->lchild);
Pop(S,p);
if(!StackEmpty(S)){
Pop(S,p); if(!Visit(p->data)) return ERROR;
Push(S,p->rchild);
}
}
return OK;
}
中序二:
Status InorderTraverse(BiTree T,Status(*Visit)(TElemType e)){
InitStack(S);p=T;
while(p||!StackEmpty(S)){
if(p){Push(S,p);p=p->lchild;}
else{
Pop(S,p); if(!Visit(p->data)) return ERROR;
p=p->rchild);
}//else
}//while
return OK;
}
五、总结
二叉树遍历的意义
相关文章推荐
- Python构建二叉树及二叉树的五种遍历
- LeetCode: 107_Binary Tree Level Order Traversal II | 二叉树自底向上的层次遍历 | Easy
- 已知二叉树的两种遍历序列,求出另一种遍历序列
- 数据结构-二叉树的各种遍历(先中后层序!!)
- 二叉树的各种遍历
- 杭电1710 Binary Tree Traversals(二叉树的遍历)
- Java写的一个二叉树三种遍历递归算法(仅用作理解三种遍历)
- 根据先序遍历和中序遍历创建二叉树
- 【算法与数据结构】二叉树的 先序 遍历
- 二叉树的遍历
- 二叉树的遍历与求深度的递归与非递归实现
- 二叉树的建立及遍历
- HRBUST - 2040 二叉树的遍历 (建树)
- 先序遍历和中序遍历创建二叉树
- -----二叉树的遍历-------
- leet102. 二叉树的层次遍历
- lintcode(M)二叉树的层序遍历II
- [LeetCode] 314. Binary Tree Vertical Order Traversal 二叉树的垂直遍历
- 遍历二叉树-递归和非递归算法
- uva11234 Expression (二叉树重建+层次遍历)