【两次过】Lintcode 467. 完全二叉树

本文介绍了一种在O(n)时间复杂度内判断二叉树是否为完全二叉树的方法,通过广度优先遍历并使用标记策略实现,提供了解决方案的详细步骤和示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

样例

例1:

输入:{1,2,3,4}
输出:true
说明:
         1
        / \
       2  3
     /
    4

是完全二叉树。

例2:

输入:{1,2,3,#,4}
输出:false
说明:
         1
        / \
       2  3
       \
        4

不是完全二叉树

挑战

在 O(n) 时间里完成

输入测试数据 (每行一个参数)如何理解测试数据?


解题思路:

使用广度优先遍历来解决。如果碰到null,但是待遍历的队列有不为空的元素,那么说明不是完全二叉树。下面方法使用flag来标记。

/**
 * Definition of TreeNode:
 * public class TreeNode {
 *     public int val;
 *     public TreeNode left, right;
 *     public TreeNode(int val) {
 *         this.val = val;
 *         this.left = this.right = null;
 *     }
 * }
 */

public class Solution {
    /**
     * @param root: the root of binary tree.
     * @return: true if it is a complete binary tree, or false.
     */
    public boolean isComplete(TreeNode root) {
        // write your code here
        if(root == null)
            return true;
            
        LinkedList<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        //用于标记当前元素是否为空,若为空,则后面元素若有一个不为空则表明不是完全二叉树
        boolean flag = false; 
        
        while(!queue.isEmpty()){
            TreeNode node = queue.poll();
            if(node != null){
                if(flag)
                    return false;
                
                queue.offer(node.left);
                queue.offer(node.right);
            }else{
                flag = true;
            }
        }
        
        return true;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值