- 浏览: 83415 次
- 性别:
- 来自: 深圳
最新评论
-
月亮不懂夜的黑:
<pre name="code" c ...
二叉树的深度优先和广度优先遍历 -
月亮不懂夜的黑:
<font color ...
二叉树的深度优先和广度优先遍历 -
zhufeng1981:
...
正在为理想而奋斗的程序员进来看看
图的深度优先搜索法是树的先根遍历的推广,它的基本思想是:从图G的某个顶点v0出发,访问v0,然后选择一个与v0相邻且没被访问过的顶点vi访问,再从vi出发选择一个与vi相邻且未被访问的顶点vj进行访问,依次继续。如果当前被访问过的顶点的所有邻接顶点都已被访问,则退回到已被访问的顶点序列中最后一个拥有未被访问的相邻顶点的顶点w,从w出发按同样的方法向前遍历,直到图中所有顶点都被访问。
图的广度优先搜索是树的按层次遍历的推广,它的基本思想是:首先访问初始点vi,并将其标记为已访问过,接着访问vi的所有未被访问过的邻接点vi1,vi2, …, vi t,并均标记已访问过,然后再按照vi1,vi2, …, vi t的次序,访问每一个顶点的所有未被访问过的邻接点,并均标记为已访问过,依次类推,直到图中所有和初始点vi有路径相通的顶点都被访问过为止。
二叉树的深度优先遍历的非递归的通用做法是采用栈,广度优先遍历的非递归的通用做法是采用队列。
为了方便程序验证,首先构造一个如图所示的二叉树。
源码:
/*************************** bintree.h文件 *****************************/
#ifndef _BINTREE_H
#define _BINTREE_H
template <class T>
class CBintree
{
public:
CBintree();
bool Depth_RF();//先根深度遍历
bool Depth_RM();//中根深度遍历
bool WidthFS(); //层次遍历
protected:
private:
struct TreeNode
{
T va;
TreeNode *plchild;
TreeNode *prchild;
};
TreeNode *m_pBintree;
};
#endif
template <class T>
CBintree<T>::CBintree()
{
m_pBintree = new TreeNode;
TreeNode *pNode2 = new TreeNode;
TreeNode *pNode3 = new TreeNode;
TreeNode *pNode4 = new TreeNode;
TreeNode *pNode5 = new TreeNode;
TreeNode *pNode6 = new TreeNode;
TreeNode *pNode7 = new TreeNode;
m_pBintree->va = (T)1;
m_pBintree->plchild = pNode2;
m_pBintree->prchild = pNode3;
pNode2->va = (T)2;
pNode2->plchild = pNode4;
pNode2->prchild = pNode5;
pNode3->va = (T)3;
pNode3->plchild = NULL;
pNode3->prchild = pNode6;
pNode4->va = (T)4;
pNode4->plchild = NULL;
pNode4->prchild = NULL;
pNode5->va = (T)5;
pNode5->plchild = pNode7;
pNode5->prchild = NULL;
pNode6->va = (T)6;
pNode6->plchild = NULL;
pNode6->prchild = NULL;
pNode7->va = (T)7;
pNode7->plchild = NULL;
pNode7->prchild = NULL;
}
template <class T>
bool CBintree<T>::Depth_RF() //先根深度遍历
{
cout << "先根遍历序列:\n";
stack <TreeNode> s;
s.push(*m_pBintree);
while (!s.empty())
{
TreeNode node_s = s.top();
cout << node_s.va << "\n";
s.pop();
if (node_s.prchild != NULL)
{
s.push(*node_s.prchild);
}
if (node_s.plchild != NULL)
{
s.push(*node_s.plchild);
}
}
return true;
}
template <class T>
bool CBintree<T>::Depth_RM() //中根深度遍历
{
cout << "中根遍历序列:\n";
stack <TreeNode> s;
TreeNode *pNode = m_pBintree;
while (pNode != NULL || !s.empty())
{
while (pNode != NULL)
{
s.push(*pNode);
pNode = pNode->plchild;
}
if (!s.empty())
{
TreeNode node_s = s.top();
cout << node_s.va << "\n";
s.pop();
pNode = node_s.prchild;
}
}
return true;
}
template <class T>
bool CBintree<T>::WidthFS() //层次遍历
{
cout << "层次遍历序列:\n";
queue <TreeNode> q;
q.push(*m_pBintree);
while (!q.empty())
{
TreeNode *pNode = &q.front();
cout << pNode->va << "\n";
if (pNode->plchild != NULL)
{
q.push(*pNode->plchild);
}
if (pNode->prchild != NULL)
{
q.push(*pNode->prchild);
}
q.pop();
}
return true;
}
/************************ main.cpp 文件 ****************************/
#include <iostream>
#include <stack>
#include <queue>
using namespace std;
#include "bintree.h"
int main()
{
CBintree <int> bt;
bt.Depth_RF();
bt.Depth_RM();
bt.WidthFS();
return 0;
}
/***************** 教科书标准算法及优化算法(转)*******************/
1.先序遍历非递归算法
void PreOrderUnrec(Bitree *t)
{
Stack s;
StackInit(s);
Bitree *p=t;
while (p!=NULL || !StackEmpty(s))
{
while (p!=NULL) //遍历左子树
{
visite(p->data);
push(s,p);
p=p->lchild;
}
if (!StackEmpty(s)) //通过下一次循环中的内嵌while实现右子树遍历
{
p=pop(s);
p=p->rchild;
}//endif
}//endwhile
}
2.中序遍历非递归算法
void InOrderUnrec(Bitree *t)
{
Stack s;
StackInit(s);
Bitree *p=t;
while (p!=NULL || !StackEmpty(s))
{
while (p!=NULL) //遍历左子树
{
push(s,p);
p=p->lchild;
}
if (!StackEmpty(s))
{
p=pop(s);
visite(p->data); //访问根结点
p=p->rchild; //通过下一次循环实现右子树遍历
}//endif
}//endwhile
}
3.后序遍历非递归算法
typedef enum{L,R} tagtype;
typedef struct
{
Bitree ptr;
tagtype tag;
}stacknode;
typedef struct
{
stacknode Elem[maxsize];
int top;
}SqStack;
void PostOrderUnrec(Bitree t)
{
SqStack s;
stacknode x;
StackInit(s);
p=t;
do
{
while (p!=null) //遍历左子树
{
x.ptr = p;
x.tag = L; //标记为左子树
push(s,x);
p=p->lchild;
}
while (!StackEmpty(s) && s.Elem[s.top].tag==R)
{
x = pop(s);
p = x.ptr;
visite(p->data); //tag为R,表示右子树访问完毕,故访问根结点
}
if (!StackEmpty(s))
{
s.Elem[s.top].tag =R; //遍历右子树
p=s.Elem[s.top].ptr->rchild;
}
}while (!StackEmpty(s));
}//PostOrderUnrec
4.前序最简洁非递归算法
void PreOrderUnrec(Bitree *t)
{
Bitree *p;
Stack s;
s.push(t);
while (!s.IsEmpty())
{
s.pop(p);
visit(p->data);
if (p->rchild != NULL) s.push(p->rchild);
if (p->lchild != NULL) s.push(p->lchild);
}
}
5.后序算法之二
void BT_PostOrderNoRec(pTreeT root)
{
stack<treeT *> s;
pTreeT pre=NULL;
while ((NULL != root) || !s.empty())
{
if (NULL != root)
{
s.push(root);
root = root->left;
}
else
{
root = s.top();
if (root->right!=NULL && pre!=root->right){
root=root->right;
}
else{
root=pre=s.top();
visit(root);
s.pop();
root=NULL;
}
}
}
}
评论
发表评论
-
java 循环打印出某对象所在类的类名和方法
2009-11-17 08:38 1470public class A { ... -
死锁的四个必要条件
2009-10-29 21:32 802操作系统中有若干进程并发执行,它们不断申请、使用、释放系统资源 ... -
java 面试题
2009-10-29 21:04 14651一、Java基础知识 1.Jav ... -
事务对数据库的重要性
2009-10-29 20:28 1139所谓事务是用户定义的 ... -
HashTable和HashMap的六点区别
2009-10-21 09:39 724HashTable和HashMap的六点区别 HashT ... -
原码、补码和反码
2009-10-18 10:41 769原 码 、 补 码 和 反 码 ... -
JSP 知识点
2009-10-11 21:28 799JSP 知识点可以用“23379”来概括,即两种注释,三种 ... -
全排序算法 java
2009-10-11 21:25 801import java.util.ArrayList; ... -
组合算法 java
2009-10-11 21:23 939import java.util.ArrayList; ... -
全排序算法
2009-10-09 21:48 863import java.util.ArrayList; ... -
计算机端口
2009-10-05 17:02 702计算机“端口”是英文p ... -
HTTP错误代码详细介绍
2009-10-05 16:57 865"100" : Co ... -
各种计算机专用名词的简写(更新中)
2009-10-05 16:33 1281ATL :(Active Template Library) ... -
网络号主机号
2009-10-05 16:17 894子网掩码 (1)子网TCP/IP网间网技术产生于 ... -
基于栈实现整数加法算法
2009-10-05 10:12 848package com.hongjindong.Stack; ... -
数据结构算法 (java描述)
2009-10-02 10:53 806http://zhangjunhd.blog.51cto.co ... -
学习笔记(2)
2009-09-07 21:27 642随机输入一个数,判断它是不是对称数(回文数)(如3,121,1 ... -
学习笔记(1)
2009-09-06 21:33 6241. 遍历字符串中的元素,并将字符串中的元素小写字母改为大写 ... -
java经典题目
2009-08-04 15:23 666l JBS1.列举出 10个JAVA语言的优势a:免费,开源, ...
相关推荐
二叉树的深度优先搜索和广度优先搜索都是常用的搜索算法,它们可以用于遍历二叉树中的所有节点。深度优先搜索可以用于查找二叉树中的某个节点,而广度优先搜索可以用于遍历二叉树中的所有节点。
本篇文章将深入探讨如何使用Java来实现二叉树的深度优先遍历(DFS, Depth First Search)和广度优先遍历(BFS, Breadth First Search)。 **深度优先遍历** 是一种在图或树中搜索的方法,它尽可能深地探索树的分支...
二叉树广度和深度优先遍历,通过递归算法实现二叉树的建立,利用递归算法实现深度优先遍历,使用队列实现广度优先遍历
总之,掌握二叉树的深度遍历和广度遍历是理解和应用数据结构的关键。通过学习这些基本操作,可以更好地解决实际问题,例如在搜索、排序、图论等领域。在实际编程中,理解并灵活运用这些方法,能够提高代码的效率和...
在这个主题下,我们将深入探讨深度优先遍历(DFS, Depth First Search)和广度优先遍历(BFS, Breadth First Search),以及在树结构中常见的先序、中序和后序遍历。这些遍历方法各有其特点,适用于不同的问题场景。...
二叉树遍历是计算机科学中处理树形结构数据时常用的一种操作,它分为深度优先搜索(DFS)和广度优先搜索(BFS)两种方式。本篇文章将重点关注广度优先搜索,即“二叉树遍历广度优先”。 广度优先搜索(BFS)是一种...
本文详细介绍了Java实现二叉树的深度优先遍历和广度优先遍历算法,通过实例代码展示了深度优先遍历和广度优先遍历的实现过程,并对二叉树的定义、深度优先遍历与广度优先遍历算法原理与相关操作实现技巧进行了详细...
本话题主要探讨如何使用非递归算法对无向图进行深度优先遍历(DFS, Depth First Search)和广度优先遍历(BFS, Breadth First Search),这两种遍历方法在图算法中有着广泛的应用。 **1. 邻接表表示法** 在处理大...
深度优先与广度优先二叉树遍历实践
### 二叉树遍历详解:深度优先与广度优先 #### 一、深度优先遍历(Depth-First Search, DFS) **深度优先遍历**是遍历二叉树的一种方式,它首先深入到某个子树的底部,然后回溯到根节点,再转向另一个子树继续探索...
深度优先搜索(DFS, Depth-First Search)和广度优先搜索(BFS, Breadth-First Search)是两种常用的遍历二叉树的方法,这两种方法各有其特点,适用于不同的场景。 深度优先搜索是一种递归的策略,它尽可能深地探索...
二叉树深度优先遍历、广度优先遍历{非递归}
在这个压缩包中,包含了一个用C语言实现的程序,用于执行图的深度优先遍历(DFS, Depth-First Search)和广度优先遍历(BFS, Breadth-First Search)。以下是这两个遍历方法的详细解释: 1. **深度优先遍历(DFS)*...
深度优先遍历的实现; 广度优先遍历的实现;
根据给定的文件信息,我们将深入探讨二叉树遍历的几种主要方式:广度优先遍历(BFS)和深度优先遍历(DFS),其中包括前序遍历、中序遍历和后序遍历。 ### 广度优先遍历(BFS) 广度优先遍历是一种按层次顺序访问...
本资料包主要探讨的是图的两种经典遍历方法:深度优先遍历(DFS,Depth-First Search)和广度优先遍历(BFS,Breadth-First Search)。 深度优先遍历是一种用于遍历或搜索树或图的算法,其基本思想是从起点开始,尽...
给定一个二叉树的数据结构,通过JavaScript实现二叉树的广度遍历和深度遍历。
二叉树遍历是访问树中所有节点的一种方法,通常分为三种主要策略:深度优先搜索(DFS)和广度优先搜索(BFS),以及非递归实现。在PHP中,这些遍历方法可以用来处理各种数据结构问题,例如解决问题、搜索和排序等。 ...
在计算机科学中,树是一种非线性数据结构,它由顶点(节点)和连接这些顶点的边组成。在处理树形结构时,遍历是...通过查看和学习这些文件,你可以更深入地了解如何在JavaScript环境下实现树的深度优先和广度优先遍历。
* 二叉树的广度优先搜索:层次遍历可以用来实现二叉树的广度优先搜索算法。 二叉树的高度 二叉树的高度是指从根节点到叶节点的最长路径长度。求二叉树的高度可以使用前序遍历算法,递归地计算每个节点的高度,并将...