前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >怎样推断一棵二叉树是全然二叉树

怎样推断一棵二叉树是全然二叉树

作者头像
全栈程序员站长
发布2022-07-12 16:20:25
1010
发布2022-07-12 16:20:25
举报

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

严蔚敏那本教材上的说法:一个深度为k,节点个数为 2^k – 1 的二叉树为满二叉树。这个概念非常好理解,

就是一棵树,深度为k,而且没有空位。

首先对满二叉树依照广度优先遍历(从左到右)的顺序进行编号。

一颗深度为k二叉树,有n个节点,然后,也对这棵树进行编号,假设全部的编号都和满二叉树相应,那么这棵树是全然二叉树。

怎样推断一棵二叉树是全然二叉树
怎样推断一棵二叉树是全然二叉树

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

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

算法例如以下:

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

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/118806.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年12月,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档