如何判断满二叉树

任意的一个二叉树,都可以补成一个满二叉树。这样中间就会有很多空洞。在广度优先遍历的时候,如果是满二叉树,或者完全二叉树,这些空洞是在广度优先的遍历的末尾,所以,但我们遍历到空洞的时候,整个二叉树就已经遍历完成了。而如果,是非完全二叉树,

我们遍历到空洞的时候,就会发现,空洞后面还有没有遍历到的值。这样,只要根据是否遍历到空洞,整个树的遍历是否结束来判断是否是完全的二叉树。

算法如下:

struct BiTree {
    int data;
    BiTree *lchild;
    BiTree *rchild;
};
bool is_complete(BiTree *root)  
{  
    queue<BiTree*> q;  
    BiTree *ptr;  
    // 进行广度优先遍历(层次遍历),并把NULL节点也放入队列  
    q.push(root);  
    while ((ptr = q.front()) != NULL)  
    {  
        q.pop();
        q.push(ptr->left);  
        q.push(ptr->right);  
    }  
  
    // 判断是否还有未被访问到的节点  
    while (!q.is_empty())  
    {  
        ptr = q.front(); 
        q.pop(); 
          
        // 有未访问到的的非NULL节点,则树存在空洞,为非完全二叉树  
        if (NULL != ptr)  
        {  
            return false;  
        }  
    }  
  
    return true;  
}  

    原文作者:满二叉树
    原文地址: https://blog.csdn.net/murongjianke001/article/details/30574121
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞