当前位置:  编程技术>c/c++/嵌入式

c++二叉树的几种遍历算法

    来源: 互联网  发布时间:2014-10-12

    本文导语:  1. 前序/中序/后序遍历(递归实现) 代码如下:// 前序遍历void BT_PreOrder(BiTreePtr pNode){ if (!pNode)  return;    visit(pNode);   BT_PreOrder(pNode->left); BT_PreOrder(pNode->right);   }// 中序遍历void BT_PreOrder(BiTreePtr pNode){  if (!pNode)  return;     B...

1. 前序/中序/后序遍历(递归实现)

代码如下:

// 前序遍历
void BT_PreOrder(BiTreePtr pNode){
if (!pNode)  return;   
visit(pNode);  
BT_PreOrder(pNode->left);
BT_PreOrder(pNode->right);   }
// 中序遍历
void BT_PreOrder(BiTreePtr pNode){ 
if (!pNode)  return;    
BT_PreOrder(pNode->left);  
visit(pNode);  
BT_PreOrder(pNode->right);}
// 后序遍历void BT_PreOrder(BiTreePtr pNode){   
if (!pNode)  return;      
BT_PreOrder(pNode->left);  
BT_PreOrder(pNode->right);   
visit(pNode);}

2. 前序遍历(非递归实现)
代码如下:

// 用栈实现
void BT_PreOrderNoRec1(BiTreePtr pNode){
stack s;
while (!pNode || !s.empty()) 
{      
if (!pNode) 
{           
visit(pNode);   
s.push(pNode);       
pNode = pNode->left;  
}      
else      
{          
pNode = s.pop();
pNode = pNode->right;    

}
}
// 用栈实现
void BT_PreOrderNoRec2(BiTreePtr pNode){
if (!pNode)  
{      
stack s; 
s.push(pNode);     
while (!s.empty())  
{          
BiTreePtr pvNode = s.pop();
visit(pvNode);         
s.push(pvNode->right);      
s.push(pvNode->left);  
}  
}}
//
不用栈实现 每个节点含父节点指针和isVisited【默认为false】状态变量 且该二叉树含一个头节点
void BT_PreOrderNoRec3(BiTreePtr pNode){   
while (!pNode)
// 回溯到指向根节点的头节点时退出 
{       
if( !pNode->bVisited )
// 判定是否已被访问   
{             
visit(pNode);   
pNode->isVisited = true;  
}       
if ( pNode->left && !pNode->left->isVisited )    
pNode = pNode->left;     
else if( pNode->right && !pNode->right->isVisited ) 
pNode = pNode->right;      
else  
//回溯    
pNode = pNode->parent; 
}}

3. 中序遍历(非递归实现)

代码如下:

// 用栈实现
void BT_InOrderNoRec1(BiTreePtr pNode){
stack s;
while (!pNode || !s.empty())  
{      
if (!pNode)      
{         
s.push(pNode);      
pNode = pNode->left;   
}  
else  
{       
pNode = s.pop(); 
visit(pNode);      
pNode = pNode->right;

}}
// 不用栈实现 每个节点含父节点指针和isVisited【默认为false】的状态变量 且该二叉树含一个头节点
void BT_InOrderNoRec2(BiTreePtr pNode){   
while (!pNode)
// 回溯到指向根节点的头节点时退出
{     
while (pNode->left && !pNode->left->isVisited)      
pNode = pNode->left;     
if (!pNode->isVisited)      
{         
visit(pNode);   
pNode->isVisited=true;  
}     
if (pNode->right && !pNode->right->isVisited) 
pNode = pNode->right;  
else         
pNode = pNode->parent;
}}

4. 后序遍历(非递归实现)
代码如下:

void BT_PostOrderNoRec(BiTreePtr pNode){
if(!pNode) return;
stack s;
s.push(pNode); 
while (!s.empty())  
{    
BiTreePtr pvNode = s.pop(); 
if (pvNode->isPushed)
// 表示其左右子树都已入栈,访问该节点      
visit(pvNode);   
else    
{       
if (pvNode->right) 
{             
pvNode->right->isPushed = false;
S.push(pvNode->right);         
}          
if (pvNode->left)    
{              
pvNode->left->isPushed = false;  
s.push(pvNode->left);         
}         
pvNode->isPushed = true;     
s.push(pvNode);   
}  
}}

5. 层序遍历(使用队列)

代码如下:

void BT_LevelOrder(BiTreePtr pNode){
if (!pNode) return;  
queue q;  
q.push(pNode); 
BiTreePtr pvNode;
while (!q.empty())
{     
pvNode = q.pop();    
visit(pvNode);  
if (pvNode->left)
q.push(pvNode->left); 
if (pvNode->right)   
q.push(pvNode->right);  
}}

    
 
 

您可能感兴趣的文章:

  • c++ stl容器set成员函数介绍及set集合插入,遍历等用法举例
  • C++实现二叉树非递归遍历方法实例总结
  • c++类库Boost.Bimap(遍历,插入,查找,删除)参考代码
  • c++遍历lua table示例
  • c++ stl容器vector删除(erase),遍历等基本用法介绍及头文件
  • c++ builder TreeView控件节点遍历代码
  • c++ STL List查找遍历及各成员函数用法详细介绍
  • C++实现二叉树遍历序列的求解方法
  • C++实现哈夫曼树简单创建与遍历的方法
  • C++非递归遍历磁盘文件和递归遍历磁盘文件的程序示例
  • 探讨:C++实现链式二叉树(用非递归方式先序,中序,后序遍历二叉树)
  • 二叉树遍历 非递归 C++实现代码
  • 二叉树前序遍历的非递归算法
  • C语言实现二叉树遍历的迭代算法
  • 基于Java实现的图的广度优先遍历算法
  • 二叉树的遍历算法(详细示例分析)
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • java map(HashMap TreeMap)用法:初始化,遍历和排序详解
  • jquery遍历筛选数组与遍历解析json对象
  • python内置映射类型(mapping type):dict哈希字典遍历方式及其它用法举例
  • php遍历数组四种方法 php数组遍历实例
  • 请问如何遍历目录并拷贝文件?使用bash Shell。
  • 高分请教高手!目录定时遍历????
  • PHP文件遍历小例子
  • C#中遍历DataSet数据集对象实例
  • php无限遍历目录代码
  • php遍历目录与其下所有文件
  • jquery进行数组遍历如何跳出当前的each循环
  • jquery遍历checkbox代码与说明
  • 请问怎么用Java实现一个URL的遍历??急!!!!
  • 请问怎样遍历一个hashtable
  • 在遍历目录的情况下如果遇到符号连接…………
  • Shell programme:怎样遍历整个/目录
  • 遍历其文件动态变化的目录
  • 求遍历文件shell
  • 求一段ShellScript,关于遍历文本文件
  • 遍历目录脚本运行出错
  • 层次遍历,结果不对


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3