Leetcode 968-监控二叉树

给定一个二叉树,我们在树的节点上安装摄像头。

节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。

计算监控树的所有节点所需的最小摄像头数量。

题解

参考自代码随想录

bash 复制代码
class Solution {
    public int result=0;
    public int minCameraCover(TreeNode root) {
        if (dfs(root) == 0) { // root 无覆盖
            result++;
        }
        return result;
        
    }

    public int dfs(TreeNode root){
        //边界条件
        // 空节点,该节点有覆盖
        if (root == null) return 2;

        int left=dfs(root.left);
        int right=dfs(root.right);

        //左右子节点有一个没有覆盖,本节点需要装监控
        if(left==0||right==0){
            result++;
            return 1;
        }
        //左右子节点有一个有监控,本节点被覆盖
        if(left==1||right==1) return 2;
        else return 0;


    }
}
相关推荐
2401_87853021几秒前
分布式任务调度系统
开发语言·c++·算法
中小企业实战军师刘孙亮2 分钟前
什么是增长陷阱?中小企业“增长陷阱”破局指南-佛山鼎策创局破局增长咨询
职场和发展·新媒体运营·创业创新·需求分析·内容运营
_深海凉_17 分钟前
LeetCode热题100-两数之和
算法·leetcode·职场和发展
nunca_te_rindas21 分钟前
算法刷体小结汇总(C/C++)20260328
c语言·c++·算法
Sunshine for you24 分钟前
高性能压缩库实现
开发语言·c++·算法
Sunshine for you25 分钟前
C++中的表达式模板
开发语言·c++·算法
qwehjk200826 分钟前
C++中的状态模式
开发语言·c++·算法
Fortune7930 分钟前
自定义类型转换机制
开发语言·c++·算法
nunca_te_rindas30 分钟前
递归实现排列型枚举题目例题
算法
2301_8145902531 分钟前
实时音频处理C++实现
开发语言·c++·算法