/*
* public class TreeNode {
* int val = 0;
* TreeNode left = null;
* TreeNode right = null;
* public TreeNode(int val) {
* this.val = val;
* }
* }
*/
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param root TreeNode类
* @return bool布尔型
*/
public boolean isCompleteTree (TreeNode root) {
// write code here
Queue<TreeNode> queue=new LinkedList<>();
queue.offer(root);
//是否遇到左右孩子不双全的节点
boolean flag=false;
while(!queue.isEmpty()){
TreeNode node=queue.poll();
//有右孩无左=
if(node.right!=null&&node.left==null) return false;
//遇到了左右孩子不双全的节点后,遇到了非叶子节点
if(flag&&(node.left!=null||node.right!=null)) return false;
//遇到了左右孩子不双全的结点
if(node.left==null||node.right==null) flag=true;
if(node.left!=null) queue.offer(node.left);
if(node.right!=null)queue.offer(node.right);
}
return true;
}
}