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;


    }
}
相关推荐
plus4s6 分钟前
2月15日(78,80,81题)
c++·算法·图论
能源系统预测和优化研究19 分钟前
【原创改进代码】考虑碳交易与电网交互波动惩罚的共享储能电站优化配置与调度模型
算法·能源
9359620 分钟前
机考27 翻译21 单词14
c语言·数据结构·算法
回敲代码的猴子2 小时前
2月14日打卡
算法
blackicexs2 小时前
第四周第七天
算法
期末考复习中,蓝桥杯都没时间学了3 小时前
力扣刷题19
算法·leetcode·职场和发展
Renhao-Wan3 小时前
Java 算法实践(四):链表核心题型
java·数据结构·算法·链表
踩坑记录4 小时前
递归回溯本质
leetcode
zmzb01034 小时前
C++课后习题训练记录Day105
开发语言·c++·算法
得一录4 小时前
AI面试·高难度题
人工智能·面试·职场和发展