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;  
}  

相关文章推荐

求C++数据结构二叉树的宽度

/*之前因为一直自己在想怎么构建二叉树,耽搁了继续去求二叉树的宽度;下面我想谈谈我自己关于怎么去求二叉树的最大宽度的想法 我非常肯定一些大神用各种简单的代码求二叉树的宽度,但是自己想出来的也是挺好的,...

二叉树的高度和宽度

  • 2016年06月10日 23:14
  • 217KB
  • 下载

[HOJ]1452 Tree Recovery(对二叉树的先序、中序、后序的熟悉与掌握)

这个题主要是由给定的二叉树的先序和中序序列来还原二叉树,并且能再给出后序序列,重点和难点都是在如何还原二叉树,后序遍历只是检测是否还原正确的一个手段而已; 由于先序序列的特点是先访问根节点在访问左右节...

数据结构课程设计二叉树的宽度

  • 2012年06月20日 13:57
  • 143KB
  • 下载

【算法导论】C++参考源码之队列、二叉树

简单的队列实现简单 #include using namespace std; //---------------------------------------------------------...

C语言实现二叉树的各种遍历及求解深度

C语言实现二叉树的各种遍历及求解深度 一、介绍        二叉树是一种重要的数据结构,在很多方面都有重要的应用,此文主要记录了二叉树的基础知识,包括二叉树的建立、前中后序遍历方式、层次遍历方式、求...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C++ HOJ 求解二叉树的宽度(队列实现)
举报原因:
原因补充:

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