当前位置: 首页 > article >正文

【贪心算法5】

力扣738.单调递增的数字

链接: link

思路

遇到c[i]>c[i+1]则c[i]–,然后就是给c[i+1]赋值‘9’;需要注意的是star初值问题,可见注释部分。

class Solution {
    public int monotoneIncreasingDigits(int n) {
        String s = String.valueOf(n);
        char[] c = s.toCharArray();
        int star = c.length; // 这里初始化必须是c.length,不能为0,因为遇到1234这个测例会出问题
        for (int i = c.length - 2; i >= 0; i--) {
            if (c[i] > c[i + 1]) {
                c[i]--;
                star = i+1; // 记录下一位起始位置
            }
        }
        for(int i = star;i<c.length;i++){
            c[i] = '9';
        }
        return Integer.parseInt(String.valueOf(c));
    }
}

相似题型

思路

设计初衷:叶子节点不放摄像头,让其父节点放
三种状态0-无覆盖;1-有摄像头;2-有覆盖;
注意考虑null节点的状态
详细思路
968.监控二叉树
链接: link

/**
 * 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;
 * }
 * }
 */
/*
 * 0-无覆盖
 * 1-有摄像头
 * 2-有覆盖
 */
class Solution {
    int res = 0;

    public int minCameraCover(TreeNode root) {
        if (afterorder(root) == 0) {
            res++;
        }
        return res;
    }

    public int afterorder(TreeNode root) {
        if (root == null) {
            return 2;
        }
        // 左
        int left = afterorder(root.left);
        int right = afterorder(root.right);
        // 如果左右节点都覆盖了的话, 中间节点就该为无覆盖
        if (left == 2 && right == 2) {
            return 0;
        } else if (left == 0 || right == 0) {
            // 左右节点都是无覆盖状态,中间节点为有摄像头
            res++;
            return 1;
        } else {
            // 左右节点至少有一个摄像头,中间节点有覆盖
            return 2;
        }
    }
}

http://www.kler.cn/a/584672.html

相关文章:

  • 使用DeepSeek完成一个简单嵌入式开发
  • 如何优化AI模型的Prompt:深度指南
  • 基于jvisualvm的内存监控与远程连接配置指南
  • K8s 1.27.1 实战系列(十)PV PVC
  • C# Unity 唐老狮 No.9 模拟面试题
  • Vue:其他指令
  • Qt的QMenu 和 QAction的样式设置
  • golang从入门到做牛马:第二十篇-Go语言接口:行为的“契约”
  • C#类型转换大总结
  • 4.3 数组和集合的初始及赋值
  • 云原生可观测性:智能运维的数据中枢
  • DeepSeek-R1深度解读
  • HarmonyOS开发 - 电商App实例三( 网络请求axios)
  • nginx中proxy_pass和root的区别
  • STL-List模拟
  • 【QT】:QT图形化界面相关准备工作
  • 【python运行Janus-Pro-1B文生图功能】
  • 开源!速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器
  • 深入理解 RTP、RTCP、RTMP、RTSP、HLS 及 live555 推拉流实现
  • 【经验分享】SpringBoot集成Websocket开发 之 使用由 Jakarta EE 规范提供的 API开发