【C++】BFS求树的高度

该博客介绍了如何通过广度优先搜索(BFS)算法来求解一般树的最大深度。首先回顾了BFS遍历二叉树的基本过程,然后详细阐述了在BFS过程中如何记录层次并计算树的高度。在求解树的最大深度时,关键在于增加一层for循环来遍历当前层的所有节点,并将未访问过的子节点加入队列。通过这种方式,可以有效地得到树的层次信息并计算出最大深度。
摘要由CSDN通过智能技术生成

思路

求树的高度本质就是层次遍历树,遍历完后记录下最大的层数,所以可以改造BFS遍历树的算法来实现求解树的最大深度

先来回顾一下BFS遍历二叉树

BFS层次遍历二叉树

其实遍历一般的树也是同样的思路,每次需要将某个节点所有的孩子都push进队列里

struct Bitree {
    int num;
    struct Bitree *lchild;
    struct Bitree *rchild;
};
queue<struct Bitree *> queue_;
struct Bitree *root = create();	//创建一棵树
queue_.push(root);
while(queue_.size()){
    tmp = queue_.front();
    queue_.pop();				
    cout << tmp->num <<endl;	//输出节点编号
    if(tmp->lchild != NULL)
        queue_.push(tmp->lchild);
    if(tmp->rchild != NULL)
        queue_.push(tmp->rchild);
}

接下来,再看一下利用BFS求一般树的最大深度

BFS求树的最大深度

struct VNode{
    int num;
    int visited;
    vector<int> list; //我们使用邻接表的方式来构建树,
    				//使用vector是很高效的方式,
    				//每次添加相邻接点只需要push_back进去就好
};    

deque<int> queue_;	//双端队列
int H = 0;			//深度
int width = 1;
while(queue_.size()){
    for(int i=0; i<width; i++){//重点是这层for循环
        temp = queue_.front();
        queue_.pop_front();     
        vnodes[temp].visited = 1;
        //将孩子push进队列
        for(int i=0; i<vnodes[temp].list.size(); i++){
            if(vnodes[vnodes[temp].list[i]].visited == 0)//未被访问过
                queue_.push_back(vnodes[temp].list[i]);
        }   
    }
    width = queue_.size();
    if(queue_.size())
        H ++;
}

与普通的BFS不同的是,在while循环里面多了一层for循环,而for循环的次数是每一层的节点数量width,当for循环结束后,本层上的所有节点都被遍历完,并且下一层的所有节点都已经push进队列里。只有当每次遍历完一层后,才能对深度H进行加1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值