资料摘自<数据结构C++语言描述>
广度优先扫描(层次扫描)算法
初始化步骤:将根节点插入到队列中
递归步骤:
1.队列为空时过程终止
2.将头节点p从队列中并打印其数据值
3.用该节点去标识位于树的下一层的子节点
if(p->Left()!= NULL)
Q.QInsert(p->Left());
if(p->Right()!= NULL)
Q.QInsert(p->Right());
以下步骤示意了树为Tree_0时的层次扫描算法
初始化:将节点A插入到队列中
1. 从队列中删除节点A。
打印A。
将A的子节点插到队列中。
左节点= B
右节点= C
2. 从队列中删除节点B。
打印B
将B的子节点插入到队列中
右节点= D
3. 从队列中删除节点C
打印C
将C的子节点插入到队列中
左节点= E
4. 从队列中删除节点D
打印D
D没有子节点
5. 从队列中删除节点E
算法终止。队列为空。
下面是实现:
template<class T>
void LevelScan(TreeNode<T> * t, void visit(T& item)){
//将每个节点的左、右节点存入队列中,使得它们在访问树的下一层次时可被顺序访问
Queue<TreeNode<T> *> Q; //Queue是队列
TreeNode<T> *p;
Q.QInsert(t); //插入到队列
while(!Q.QEmpty()){
p = Q.QDelete();
visit(p->data);
if(p->Left() != NULL){
Q.QInsert(p->Left()); //插入左节点到队列
}
if(p->Right() != NULL){
Q.QInsert(p->Right()); //插入右节点到队列
}
}
}