【算法刷题day37】Leetcode:738. 单调递增的数字、968. 监控二叉树

文章目录

草稿图网站
java的Deque

Leetcode 738. 单调递增的数字

题目: 738. 单调递增的数字
解析: 代码随想录解析

解题思路

这贪心有点巧,自己没想出来。从后往前遍历,如果遇到了比后面小的,就让当前数减一。遍历结束后,让修改的数字的后面所有都变成9

代码

java 复制代码
class Solution {
    public int monotoneIncreasingDigits(int n) {
         String s = String.valueOf(n);
         char[] chars = s.toCharArray();
         int start = chars.length;
         for (int i = chars.length - 2; i >= 0; i--) {
            if (chars[i] > chars[i+1]) {
                chars[i]--;
                start = i+1;
            }
         }
         for (int i = start; i < chars.length; i++) {
            chars[i] = '9';
         }
         return Integer.parseInt(String.valueOf(chars));
    }
}

总结

暂无

Leetcode 968. 监控二叉树

题目: 968. 监控二叉树
解析: 代码随想录解析

解题思路

自己根本想不到,这题的贪心算法需要把问题抽象化。

把空节点当作已覆盖(2)。

如果左孩子、右孩子都为已覆盖(2),则当前节点为未覆盖(0)

如果左孩子或右孩子存在未覆盖(0),则当前节点加一个监控(1)

如果左孩子或右孩子有监控(1),则当前节点为已覆盖(2)

代码

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    int res;
    public int minCameraCover(TreeNode root) {
        //0表示没覆盖
        //1表示安装监控
        //2表示被覆盖

        res = 0;
        if (traversal(root) == 0)
            res++;
        return res;
    }

    private int traversal(TreeNode node) {
        if (node == null)
            return 2;
        int left = traversal(node.left);
        int right = traversal(node.right);

        if (left == 2 && right == 2)
            return 0;
        if (left == 0 || right == 0){
            res++;
            return 1;
        }
        if (left == 1 || right == 1)
            return 2;
        return -1;
    }
}

总结

相关推荐
zone77395 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub7 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub7 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub7 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙8 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
xlp666hub11 小时前
Leetcode第五题:用C++解决盛最多水的容器问题
linux·c++·leetcode
CoovallyAIHub11 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库12 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语071612 小时前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法