美文网首页
判断一棵树是否是完全二叉树

判断一棵树是否是完全二叉树

作者: Ramsey16k | 来源:发表于2019-11-27 17:30 被阅读0次

按层遍历,存在两种情况:
(1)当前节点有右孩子却没有左孩子,一定不是完全二叉树
(2)当前节点不是同时有左右两个孩子的时候,后面遍历到的所有节点都必须是叶节点,否则不是完全二叉树

具体方法在注释写的很清楚,代码如下:

public class IsCBT {
    public static class Node {
        public int value;
        public Node left;
        public Node right;

        public Node(int data) {
            this.value = data;
        }
    }

    public static boolean isCBT(Node head) {
        if (head == null) {
            return true;
        }
        Queue<Node> queue = new LinkedList<>();
        boolean leaf = false; // 是否进入判断叶子节点的阶段
        Node l;
        Node r;
        queue.offer(head);
        while (!queue.isEmpty()) {
            head = queue.poll(); // 从队列里弹出当前节点
            l = head.left;
            r = head.right;
            if ((leaf && (l != null || r != null)) // 开启了判断叶子节点的阶段,且当前节点不是叶子节点(存在左、右孩子)
                    ||
                    (l == null && r != null)) { // 左孩子为空,右孩子不为空
                return false;
            }
            // 既然是按层遍历,就应该先加左孩子,再加右孩子
            if (l != null) {
                queue.offer(l);
            }
            if (r != null) {
                queue.offer(r);
            } else { // 左孩子 或 右孩子为空
                leaf = true; // 进入判断叶子节点的阶段
            }
        }
        return true;
    }

    public static void main(String[] args) {
        Node head = new Node(4);
        head.left = new Node(2);
        head.right = new Node(6);
        head.left.left = new Node(1);
        head.left.right = new Node(3);
        head.right.left = new Node(5);

        System.out.println(isCBT(head));

    }
}

相关文章

  • 判断一棵树是否是搜索二叉树、判断一棵树是否是完全二叉树

    题目描述 判断一棵树是否是搜索二叉树、判断一棵树是否是完全二叉树 什么是二叉查找树? 二叉查找树(Binary S...

  • 判断完全二叉树

    判断一棵树是否是完全二叉树(1)若root为空则不是。(2)如果不为空,怎对二叉树进行层序遍历。(2.1)如果节点...

  • 958. 二叉树的完全性检验

    判断是否是完全二叉树 给定一个二叉树,确定它是否是一个完全二叉树。 百度百科中对完全二叉树的定义如下: 若设二叉树...

  • Check Completeness Of A Binary T

    问题 判断一棵树是否是完全二叉树 思路 观察测试数据[1,2,3,4,5,6] [1,2,3,4,5,null,7...

  • 二叉树常见问题

    1 判断类问题 判断类问题主要分判断二叉树是否是二叉搜索树、二叉完全树,以及两棵二叉树是否同构这三个问题。 1.1...

  • 关于二叉树的算法题

    前序遍历中序遍历后序遍历判断是否是平衡二叉树判断是否是对称二叉树判断二叉树高度按照层遍历二叉树判断二叉树宽度

  • leetcode-Easy-29-Tree-Same tree

    题目判断二叉树是否完全一样 Given two binary trees, write a function to...

  • 每日算法题—二叉树完全性校验

    题目描述 校验一棵树是否为完全二叉树 完全二叉树定义:若设二叉树的深度为 h,除第 h 层外,其它各层 (1~h-...

  • 判断树是否是完全二叉树

    算法思想: 遇到第一个没有左儿子或者右儿子的节点,设置标志位,如 果之后再遇到有左右儿子的节点,那么这不是一颗完...

  • 1 二叉树的最近公共祖先(leetcode 236) 2 判断是否为平衡二叉树 3 判断二叉树是否为满二叉树 4 ...

网友评论

      本文标题:判断一棵树是否是完全二叉树

      本文链接:https://www.haomeiwen.com/subject/hgvbwctx.html