数据结构:二叉树的访问--广度优先遍历法

资料摘自<数据结构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());    //插入右节点到队列
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值