完全二叉树的判断
什么是完全二叉树?
一棵深度为k的有n个结点的 二叉树 ,对树中的结点按从上至下、从左到右的顺序进行编号,如果编号为i(1≤i≤n)的结点与 满二叉树 中编号为i的结点在二叉树中的位置相同,则这棵二叉树称为完全二叉树(百度)
判断是不是完全二叉树条件有两点
第一点:任意结点,有右无左,就不是完全二叉树
第二点:在第一点不违规的情况下,如果遇到了第一个左右子树不全的结点,后序皆是叶结点
-
private static boolean isBST(Node head){
-
if(head == null){
-
return true;
-
}
-
//和先遍历一样,用一个队列存储结点
-
Queue<Node> queue = new LinkedList<>();
-
Node left = null;
-
Node right = null;
-
//记录遇到了第一个左右不满的结点
-
boolean leaf = false;
-
queue.add(head);
-
while(!queue.isEmpty()){
-
head = queue.poll();
-
left = head.left;
-
right = head.right;
-
//如果leaf为ture那么就已经遇到了第一个左右不满的结点,
-
// 往后遍历过程中只有当左右孩子都为空时才是完全二叉树
-
if((leaf && (left != null || right != null)) ||
-
//有右孩子无左孩子
-
(left == null && right != null)){
-
return false;
-
}
-
if(left != null){
-
queue.add(left);
-
}
-
if(right != null){
-
queue.add(right);
-
}
-
//当左右孩子中有一个为空,leaf就标记
-
if(left == null || right == null){
-
leaf = true;
-
}
-
}
-
return true;
-
}
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhggfjfe
系列文章
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01