贪心算法解决单调递增数字问题

代码随想录链接:代码随想录

思路:

定义一个变量flag,表示需要将之后的数字全部变成9的位置

从后遍历数字中的每一位,如果遍历到第i位数字时它的前一位数字比它大(严格大于),令它前一位数字减1,同时令flag=i

遍历结束后,令该数字的第flag位及其之后的全部数字都变成9

最后返回最终的数字即可

代码:

java 复制代码
class Solution {
    public int monotoneIncreasingDigits(int N) {
        String[] strings = (N + "").split("");
        int start = strings.length;
        for (int i = strings.length - 1; i > 0; i--) {
            if (Integer.parseInt(strings[i]) < Integer.parseInt(strings[i - 1])) {
                strings[i - 1] = (Integer.parseInt(strings[i - 1]) - 1) + "";
                start = i;
            }
        }
        for (int i = start; i < strings.length; i++) {
            strings[i] = "9";
        }
        return Integer.parseInt(String.join("",strings));
    }
}
相关推荐
leobertlan14 小时前
好玩系列:用20元实现快乐保存器
android·人工智能·算法
青梅橘子皮14 小时前
C语言---指针的应用以及一些面试题
c语言·开发语言·算法
_深海凉_15 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode
被开发耽误的大厨18 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang00732118 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆19 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)20 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野21 小时前
刷题:数组
数据结构·算法
tankeven21 小时前
HJ182 画展布置
c++·算法
CS_Zero1 天前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机