二叉树的遍历的迭代和递归实现方式
来源:互联网 发布:mmd是什么软件 编辑:程序博客网 时间:2024/05/29 17:46
二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有前序、中序以及后序三种遍历方法。因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁。而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现。在三种遍历中,前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点。
一.前序遍历
前序遍历按照“根结点-左孩子-右孩子”的顺序进行访问。
1.递归实现
void preOrder1(BinTree *root) //递归前序遍历
{
if(root!=NULL)
{
cout<<root->data<<" ";
preOrder1(root->lchild);
preOrder1(root->rchild);
}
}
2.非递归实现
根据前序遍历访问的顺序,优先访问根结点,然后再分别访问左孩子和右孩子。即对于任一结点,其可看做是根结点,因此可以直接访问,访问完之后,若其左孩子不为空,按相同规则访问它的左子树;当访问其左子树时,再访问它的右子树。因此其处理过程如下:
对于任一结点P:
1)访问结点P,并将结点P入栈;
2)判断结点P的左孩子是否为空,若为空,则取栈顶结点并进行出栈操作,并将栈顶结点的右孩子置为当前的结点P,循环至1);若不为空,则将P的左孩子置为当前的结点P;
3)直到P为NULL并且栈为空,则遍历结束。
void preOrder2(BinTree *root) //非递归前序遍历
{
stack<BinTree*> s;
BinTree *p=root;
while(p!=NULL||!s.empty())
{
while(p!=NULL)
{
cout<<p->data<<" ";
s.push(p);
p=p->lchild;
}
if(!s.empty())
{
p=s.top();
s.pop();
p=p->rchild;
}
}
}
二.中序遍历
中序遍历按照“左孩子-根结点-右孩子”的顺序进行访问。
1.递归实现
void inOrder1(BinTree *root) //递归中序遍历
{
if(root!=NULL)
{
inOrder1(root->lchild);
cout<<root->data<<" ";
inOrder1(root->rchild);
}
}
2.非递归实现
根据中序遍历的顺序,对于任一结点,优先访问其左孩子,而左孩子结点又可以看做一根结点,然后继续访问其左孩子结点,直到遇到左孩子结点为空的结点才进行访问,然后按相同的规则访问其右子树。因此其处理过程如下:
对于任一结点P,
1)若其左孩子不为空,则将P入栈并将P的左孩子置为当前的P,然后对当前结点P再进行相同的处理;
2)若其左孩子为空,则取栈顶元素并进行出栈操作,访问该栈顶结点,然后将当前的P置为栈顶结点的右孩子;
3)直到P为NULL并且栈为空则遍历结束
void inOrder2(BinTree *root) //非递归中序遍历
{
stack<BinTree*> s;
BinTree *p=root;
while(p!=NULL||!s.empty())
{
while(p!=NULL)
{
s.push(p);
p=p->lchild;
}
if(!s.empty())
{
p=s.top();
cout<<p->data<<" ";
s.pop();
p=p->rchild;
}
}
}
三.后序遍历
后序遍历按照“左孩子-右孩子-根结点”的顺序进行访问。
1.递归实现
void postOrder1(BinTree *root) //递归后序遍历
{
if(root!=NULL)
{
postOrder1(root->lchild);
postOrder1(root->rchild);
cout<<root->data<<" ";
}
}
2.迭代实现
先找到最左边的叶子并把路上遇到的节点一次进栈,然后弹出栈顶的元素(该元素为最左边的叶子)并判断(1)它有没有右节点;
(2)右节点是否被访问过;如果有右节点同时没被访问过,则先压入刚才弹出的元素,然后压入它的右子树,否则访问该节点并设置pre为该节点。
void postOrder2(BinTree *root) //非递归后序遍历
{
stack<BinTree*> s;
BinTree *p=root;
BinTree *pre=NULL;
BinTree *top=NULL;
while(p!=NULL||!s.empty())
{
while(p!=NULL)
{
s.push(p);
p=p->lchild;
}
if(!s.empty())
{
top=s.top();
if(top->right!=NULL&&top->right!=pre)
{
p=p->right;
}
else
{
cout<<top->data<<" "
pre=top;
s.pop()
}
}
}
}
——转载自:http://www.2cto.com/kf/201308/233002.html
- 二叉树的三种遍历方式的递归实现和迭代实现
- 二叉树的遍历的迭代和递归实现方式
- 二叉树遍历的所有递归和迭代实现
- Java 二叉树的前序、中序、后续遍历 递归和迭代实现
- 二叉树之中序遍历的递归和迭代实现
- 二叉树三种遍历的递归和迭代解法
- 二叉树的递归、迭代遍历的模板代码
- 二叉树的三种遍历方式的递归实现和非递归实现
- 二叉树的遍历(递归与迭代)
- 二叉树的实现和递归遍历
- 二叉树的前中后序遍历,递归和非递归方式
- 二叉树的三种遍历方式(递归和非递归的实现方法)
- 以二叉树的前序遍历为例,递归和非递归方式的实现
- 二叉树三种遍历方式的递归和循环实现
- 二叉树的三种遍历方式的循环和递归的实现方式
- 二叉树的3中遍历方法(递归和迭代)
- 二叉树的几种遍历方法,包括递归和迭代
- java实现二叉树的递归方式遍历
- LED跑马灯之二
- FOOD COOKING
- web页面的数据导入到excel的方法
- opencv 矩阵的存取
- 【Nginx】Nginx配置文件nginx.conf中文详解
- 二叉树的遍历的迭代和递归实现方式
- 总结集成支付宝, 遇到的各种问题
- Msdao15调用oracle存储过程
- 90后走入地下市场成为勒索软件的幕后人
- JavaScript查找Html字符串中的img标签替换src属性的内容
- 【排序算法4】选择排序
- 总结整理时下流行的浏览器User-Agent大全
- Maven最佳实践:版本管理
- old couple story