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

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

思路:

定义一个变量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));
    }
}
相关推荐
C蔡博士3 分钟前
计算复杂性:P、NP、NP-hard、NP-complete 一篇通关
算法·计算理论·np问题·计算复杂性
add45a11 分钟前
C++与自动驾驶系统
开发语言·c++·算法
TsukasaNZ17 分钟前
C++中的命令模式
开发语言·c++·算法
superkcl202232 分钟前
指针常量有什么用呢?
开发语言·c++·算法
华清远见成都中心33 分钟前
嵌入式春招笔试高频算法题(附解题思路)
算法
像污秽一样38 分钟前
算法设计与分析-习题9.1
数据结构·算法·dfs·dp·贪婪
無限進步D43 分钟前
差分算法 cpp
c++·算法·蓝桥杯·竞赛
星空露珠1 小时前
迷你世界UGC3.0脚本Wiki生物模块管理接口 Monster
开发语言·数据结构·算法·游戏·lua
星空露珠1 小时前
迷你世界UGC3.0脚本Wiki世界模块管理接口 World
开发语言·数据库·算法·游戏·lua
阿贵---1 小时前
C++中的装饰器模式
开发语言·c++·算法