C++ HOJ 求解二叉树的宽度(队列实现)

原创 2015年07月07日 21:36:37

【摘要】

我们可以把二叉树中每层的节点依次放入一个队列中。设置一个变量width用于存储树的宽度。每一层的节点入队时计算该层节点的数目,如果该层次节点的数目大于width的值,那么把该层次节点的数目赋给width.如此,对二叉树按层遍历一遍之后width中保存的就是该二叉树的宽度。

【算法思想】

队列实现层次遍历,找到下一层的子节点入队,子节点一次遍历保证一次单层测宽,最终获取树宽。

【源码实现】

int WidthOfTheTree(Node* pRoot)  
{  
    if(pRoot==NULL)  
        return 0;  
    queue<Node*> MyQueue2;  
    MyQueue2.push(pRoot);  
    int width=1;  
    int curwidth=1;  
    int nextwidth=0;  
    while(!MyQueue2.empty())  
    {  
        while(curwidth!=0)  
        {  
            Node* pTmp=MyQueue2.front();  
            MyQueue2.pop();  
            curwidth--;  
            if(pTmp->pLeft!=NULL)  
            {  
                MyQueue2.push(pTmp->pLeft);  
                nextwidth++;  
            }  
            if (pTmp->pRight!=NULL)  
            {  
                MyQueue2.push(pTmp->pRight);  
                nextwidth++;  
            }  
        }  
        if(nextwidth>width)  
            width=nextwidth;  
        curwidth=nextwidth;  
        nextwidth=0;  
    }  
    return width;  
}  

版权声明: 举报

相关文章推荐

求二叉树的深度和宽度

// 求二叉树的深度和宽度.cpp : 定义控制台应用程序的入口点。 #include "stdafx.h" #include #include using namespace std; st...

求二叉树的深度和宽度

二叉树的深度:从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。 二叉树的宽度:二叉树的每一层中都有一定数量的节点,节点数最多的那一层的节点数叫做二叉树的宽度。...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

二叉树宽度

代码如下: //node.h struct node{ int value; node *lchild; node *rchild; }; //tree.h #include "node...

二叉树的宽度(二叉树)

1.题目:  Problem Description 二叉树的宽度是指二叉树各层结点数的最大值。设有一棵二叉树,其节点值为字符型并假设各值互不相等,采用二叉链表存储表示。设计一个算法,输出...

二叉树系列——二叉树的宽度(百度面试题)

所谓二叉树的宽度是指:二叉树各层节点个数的最大值。 我们知道层序遍历二叉树是使用deque来实现的:每次打印一个节点之后,如果存在左右子树,则把左右子树压入deque,那么此时的队列中可能既包含当前层...

二叉树的宽度

二叉树的宽度就是每一层的宽度的最大值 要求二叉树的宽度,不许先求出每一层的宽度,求每一层的宽度必须知道每一层的元素 作为初学的我,看到树本来就是从括号表示来的,所以我在这里借助里开始时候的树的括号...

二叉队列的实现

头文件: /* *A class for Minimum BinaryHeap *writter: flyaway *Time: 2012.5.22 *description: * use th...

二叉树的基本操作

二叉树的实现:#include #include #include #include #include using namespace std;//二叉树节点 template struct Bina...

二叉树 队列实现 模板

#include #include #include //在本程序中空==0 using namespace std; #define FLASE 0 #define TRUE 1 #def...

二叉树的实现

二叉树的实现
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)