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

738. 单调递增的数字

总体思想就是从后往前遍历,比较第i位和第i+1位的大小,不符合顺序char[i]减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#贪心每周总结

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

相关推荐
计算机安禾9 分钟前
【c++面向对象编程】第46篇:CRTP(奇异递归模板模式):静态多态的妙用
开发语言·c++·算法
广州灵眸科技有限公司15 分钟前
瑞芯微(EASY EAI)RV1126B 音频电路
开发语言·人工智能·深度学习·算法·yolo·音视频
Dlrb121131 分钟前
数据结构-链表
数据结构·链表·逻辑结构·单向链表·物理结构·valgrind工具
小的~~37 分钟前
算法题:只出现一次的数字
数据结构·算法
灵智实验室38 分钟前
PX4状态估计技术EKF2详解(六):EKF2 磁力计融合——从航向修正到 3D 姿态约束
算法·无人机·px 4
JieE21241 分钟前
手把手带你用虚拟头节点实现单链表,搞定所有边界问题
javascript·算法
一切皆是因缘际会1 小时前
从概率拟合到内生心智:七层投影架构重构AGI数字生命新范式
大数据·数据结构·人工智能·重构·架构·agi
历程里程碑1 小时前
56 . 高效ET非阻塞IO服务器设计指南
java·运维·服务器·开发语言·数据结构·c++·排序算法
搞科研的小刘选手1 小时前
【大连市计算机学会主办】第三届图像处理、智能控制与计算机工程国际学术会议(IPICE 2026)
图像处理·人工智能·深度学习·算法·计算机·数据挖掘·智能控制
南境十里·墨染春水1 小时前
数据结构 —— 顺序表
数据结构