您的位置:首页 > 其它

完全二叉树的判断

2015-10-16 21:28 274 查看
bool is_complete(Tree *root)

{
queue<Tree *> q;
Tree *ptr;
// 进行广度优先遍历(层次遍历),并把NULL节点也放入队列
q.push(root);
while ((ptr = q.pop()) != NULL)
{
q.push(ptr->left);
q.push(ptr->right);
}

// 判断是否还有未被访问到的节点
while (!q.is_empty())
{
ptr = q.pop();

// 有未访问到的的非NULL节点,则树存在空洞,为非完全二叉树
if (NULL != ptr)
{
return false;
}
}

return true;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: