社区
C++ 语言
帖子详情
大虾们,请教一下:如何用算法实现判断一棵树是否是完全二叉树?
啊啊奔驰车
2004-11-21 10:33:41
如何用算法实现判断一棵树是否是完全二叉树?
...全文
1119
20
打赏
收藏
大虾们,请教一下:如何用算法实现判断一棵树是否是完全二叉树?
如何用算法实现判断一棵树是否是完全二叉树?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
20 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
asimpleman
2004-12-05
打赏
举报
回复
g
xiaozscs
2004-12-05
打赏
举报
回复
MARK!
260005065
2004-12-05
打赏
举报
回复
满二叉树就是完全二叉树(一定是),完全二叉树不一定是满二叉树。
还是用队列层次遍历吧,不用求深度。
setQ(&Q,50);
insQ(&Q,root);
while(!empQ(&Q)) //非空
{
if(p=NULL&&!empQ(&Q))
return 0;
p=getQ(&Q);
if(p->left!=NULL||p->right!=NULL)
{
insQ(&Q,p->left);
insQ(&Q,p->right);
}
}
return 1;
cao12m
2004-12-05
打赏
举报
回复
求广度哈哈!!!广度不能求撒 来捣乱的~~~哈哈哈
Leaveye
2004-11-22
打赏
举报
回复
根据是:完全二叉树可以连续存储在一个空间里。(好象叫做堆)
Leaveye
2004-11-22
打赏
举报
回复
: 1
/ \
2 3
/ \ /
4 5 6
遍历一次这个二叉树。在遍历过程中记录两个值,一个是当前已经遍历的变量数(如 Counter),一个是最大的变量号(如 LastNum)。变量编号按以下规则分配:
⑴ 根结点编号为 1 ;
⑵ 对于某个编号为 n 的结点,其左子结点(若存在)的编号为 2n,其右子结点(若存在)的编号为 2n + 1。
遍历完成后,得到两个号码,对其比较,若 Counter 与 LastNum 相等,则说明是完全二叉树,若 LastNum 较大,则不是。
260005065
2004-11-22
打赏
举报
回复
前面的说的不完全:
比如
1
/ \
2 3
/ \ \
4 5 6
满足叶子都是3,但不是完全二叉树。
所以不光要判断深度,在遍历过程中要判断
if(root->left==NULL&&root->right!=NULL) return false;
weqi
2004-11-22
打赏
举报
回复
Mark一下
carbonic
2004-11-22
打赏
举报
回复
满二叉树就是完全二叉树(一定是),完全二叉树就是满二叉树。
北极猩猩
2004-11-22
打赏
举报
回复
forever C++说得没错。
通过一次遍历就可以计算深度和节点个数,只要满足条件就是完全二叉树
YAMABACK
2004-11-22
打赏
举报
回复
如老迈马甲NO.1所说,完全二叉树的节点个数是2n-1,其中n是层数
xuzheng318
2004-11-22
打赏
举报
回复
1.做一算法用来求该树有多少接点 =(Number)
//该写输出接点的函数就可得到
2.做另一算法用来求该书的深度 =(Depth)
//书点的考研题
通过公式: if ( 2的(Depth - 1)次方 == Number )
then
//是完全二杈树
cici7788
2004-11-22
打赏
举报
回复
能不能通过节点编号的关系实现呢?如果父节点编号为I,则左孩子为2I,右孩子为2I+1。
sunxysong
2004-11-22
打赏
举报
回复
同意 260005065(懒在床上不起) 的,用队列感觉比较好
260005065
2004-11-22
打赏
举报
回复
楼上3 位,您们说的是满二叉树吧?好象不是完全二叉树啊!!
260005065
2004-11-22
打赏
举报
回复
贴错了,从贴一下。。。
^_^
还是用队列层次遍历吧,不用求深度。
setQ(&Q,50);
insQ(&Q,root);
while(!empQ(&Q)) //非空
{
p=getQ(&Q);
if(p=NULL)
{
if(empQ(&Q))
return 1;
else
return 0;
}
if(p->left!=NULL||p->right!=NULL)
{
insQ(&Q,p->left);
insQ(&Q,p->right);
}
}
260005065
2004-11-22
打赏
举报
回复
还是用队列层次遍历吧,不用求深度。
setQ(&Q,50);
insQ(&Q,root);
while(!empQ(&Q)) //非空
{
if(p=NULL&&!empQ(&Q))
return 0;
p=getQ(&Q);
if(p->left!=NULL||p->right!=NULL)
{
insQ(&Q,p->left);
insQ(&Q,p->right);
}
}
return 1;
steppewolf
2004-11-21
打赏
举报
回复
好主意
try876
2004-11-21
打赏
举报
回复
正如楼上说的,
可以随便用一种遍历方式(如前序),遍历到叶子节点时记录它的深度到一个变量d,
第二次以后每次到叶子时,判断是不是等于d,如果不是,直接返回false(不是完全二叉树)
hlnpro
2004-11-21
打赏
举报
回复
如果完全二叉树定义记得对,好像可以遍历时记录根到各个叶子节点的深度,最后比较各叶子节点的深度,如全相等就是完全二叉树。
数据结构与
算法
:
判断
是不是
完全二叉树
判断
是不是
完全二叉树
常考数据结构与
算法
:
判断
二叉树是否对称(迭代法,递归法)
给定一棵二叉树,
判断
琪
是否是
自身的镜像(即:是否对称) 例如:下面这棵二叉树是对称的 1 / \ 2 2 / \ / \ 3 4 4 3 下面这棵二叉树不对称。 1 / \ 2 2 \ \ 3 3 思路:要
判断
一颗二叉树是否对称,要
判断
一下
几点,可以用递归来
实现
:
判断
一颗二叉树是不是对称的,等价于
判断
其左右子树是不是镜像对称的
判断
镜对称像即
判断
对称的位置上的元素是不是相等 两个节点A和B对称等价于...
数据结构与
算法
:
判断
是不是二叉搜索树
判断
是不是二叉搜索树
常考数据结构与
算法
:平衡二叉树
题目描述 输入一棵二叉树,
判断
该二叉树
是否是
平衡二叉树。 在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树 平衡二叉树(Balanced Binary Tree),具有以下性质:它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。 如下为平衡二叉树 如下为非平衡二叉树 class TreeNode { int val; TreeNode left; TreeNode right; Tr...
数据结构与
算法
:二叉树的中序遍历
二叉树的中序遍历
C++ 语言
64,654
社区成员
250,484
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章