Day37|贪心算法part06:738.单调递增的数字、968. 监控二叉树、贪心总结

738. 单调递增的数字

总体思想就是从后往前遍历,比较第i位和第i+1位的大小,不符合顺序chari减1,i+1位填9,找到需要填9的最先位置,然后填9。

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

968. 监控二叉树

https://programmercarl.com/0968.监控二叉树.html#思路

这题之前完全没做过,直接看题解了。

  • 贪心:尽可能把摄像头放在非叶子结点,且从下往上看(指数级更省(
  • 此时,大体思路就是从低到上,先给叶子节点父节点放个摄像头,然后隔两个节点放一个摄像头,直至到二叉树头结点。

直接看代码,这里构造了虚拟根节点来将处理root的逻辑一般化:

cpp 复制代码
class Solution {
        private int res = 0;

        private int traversal(TreeNode node){
            //0表示没被覆盖;
            //1表示装了摄像头;
            //2表示状态是被覆盖到。
            if(node == null){
                return 2;//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;
            }
            //左右有一个装了摄像头,本节点被照到
//            else if(left == 1 || right == 1){
//                return 2;
//            }
            else {
                return 2;
            }

        }
        public int minCameraCover(TreeNode root) {
            //考虑根节点是否被覆盖
            TreeNode dummyRoot = new TreeNode();
            dummyRoot.left = root;
            traversal(dummyRoot);

            return res;
        }
    }

贪心总结

https://programmercarl.com/贪心算法总结篇.html#贪心每周总结

最近发现总结还有每道题的总结,之后大批量刷的时候根据总结去刷题。

相关推荐
Jerry14 分钟前
LeetCode 209. 长度最小的子数组
算法
彦为君41 分钟前
算法思维与经典智力题
java·前端·redis·算法
智能优化与强化学习1 小时前
Gym(Gymnasium)仿真环境详解(二):环境简介、入门算法、调参要点、核心挑战
算法·强化学习·gym·零基础入门·算法评估
mxwin1 小时前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader
“码”力全开1 小时前
AI视频分析误报优化完整流程
算法·架构·边缘计算
深盾科技_Virbox1 小时前
深盾科技·Virbox产品体系全景解读:软件安全如何从加密锁走向全生命周期
java·大数据·算法·安全·软件需求
可编程芯片开发2 小时前
基于VSG虚拟同步发电机控制的三相并网逆变器带多组可变负载Simulink建模与仿真
算法
AI服务老曹2 小时前
国产NPU视觉算法参数配置说明
算法·性能优化·边缘计算
彦为君2 小时前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
触底反弹3 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法