编写程序判别给定二叉树是否为完全二叉树。 5

 我来答
屋石
推荐于2018-02-28 · TA获得超过5354个赞
知道大有可为答主
回答量:1909
采纳率:86%
帮助的人:914万
展开全部
int JudgeComplete(BiTree bt) //判断二叉树是否是完全二叉树,如是,返回1,否则,返回0
{int tag=0; BiTree p=bt, Q[]; // Q是队列,元素是二叉树结点指针,容量足够大
if(p==null) return (1);
QueueInit(Q); QueueIn(Q,p); //初始化队列,根结点指针入队
while (!QueueEmpty(Q))
{p=QueueOut(Q); //出队
if (p->lchild && !tag) QueueIn(Q,p->lchild); //左子女入队
else {if (p->lchild) return 0; //前边已有结点为空,本结点不空
else tag=1; //首次出现结点为空
if (p->rchild && !tag) QueueIn(Q,p->rchild); //右子女入队
else if (p->rchild) return 0; else tag=1;
} //while
return 1; } //JudgeComplete
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2019-09-09
展开全部
bool check(BiTree T)
{ if (T == NULL) return false;
queue<BiTree> Q;
Q.push(T); while (!Q.empty())
{
BiTree p = Q.front();
Q.pop(); if (p->left && p->right) {
Q.push(p->left);
Q.push(p->right);
} else if(p->right && p-left == NULL) return false; else
{ if(p->left && p-right == NULL)
Q.push(p->left); while(!Q.empty())
{
p = Q.front(); Q.pop(); if(p->left || p->right) return false;
}

}
} return true;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式