代码随想录算法训练营第三十七天| LeetCode 738.单调递增的数字、总结

一、LeetCode 738.单调递增的数字

题目链接/文章讲解/视频讲解:https://programmercarl.com/0738.%E5%8D%95%E8%B0%83%E9%80%92%E5%A2%9E%E7%9A%84%E6%95%B0%E5%AD%97.html

状态:已解决

1.思路

如何求得小于等于N的最大单调递增的整数?98,一旦出现strNum[i - 1] > strNum[i]的情况(非单调递增),首先想让strNum[i - 1]--,然后strNum[i]给为9,这样这个整数就是89,即小于98的最大的单调递增整数。也就是说,我们只需要找到最先不满足单增性质的位置,然后将前一个元素-1,后面的所有元素变为9即可。因此,代码分两步:

(1)找到整数中最先不满足单增性质的前后元素:

遍历数组,比较前后两个元素的大小,然后不断维护前者大于后者的最新下标。此时是从前向后遍历还是从后向前遍历呢?从前向后遍历的话,遇到strNum[i - 1] > strNum[i]的情况,让strNum[i - 1]减一,但此时如果strNum[i - 1]减一了,可能又小于strNum[i - 2]。这么说有点抽象,举个例子,数字:332,从前向后遍历的话,那么就把变成了329,此时2又小于了第一位的3了,真正的结果应该是299。那么从后向前遍历,就可以重复利用上次比较得出的结果了,从后向前遍历332的数值变化为:332 -> 329 -> 299。

(2)后面所有元素变为9

从维护的位置开始,到整数末,每个数都变为9。

2.代码实现

cpp 复制代码
class Solution {
public:
    int monotoneIncreasingDigits(int n) {
        string s = to_string(n);
        int pos = s.size();//注意初值值设为数组末,以便找不到不符合单增性质的位置时,
        //让第二个循环不做
        for(int i=s.size()-1;i>0;i--){
            if(s[i-1] > s[i]){
                s[i-1]--;
                pos = i;
            }
        }
        for(int i=pos;i<s.size();i++){
            s[i] = '9';
        }
        return stoi(s);
    }
};

二、总结

1.贪心简单题

以下三道题目就是简单题,可以初步理解贪心的概念。

2.贪心中等题

(1)这两类属于第一次接触较为难想的题,偏数学。

(2)贪心解决股票问题

一般的股票问题是动规的领域,但部分用贪心也可以解决,以下是比较经典的两道可以贪心完成的股票问题。

(3)两个维度的题

在出现两个维度相互影响的情况时,两边一起考虑一定会顾此失彼,要先确定一个维度,再确定另一个一个维度。

3.贪心难题

(1)贪心解决区间问题

主要是一些区间覆盖问题,如何统计如何去除。

(2)无规律的题

贪心算法:最大子序和 (opens new window)

贪心算法:加油站 (opens new window)

4.总览

相关推荐
却话巴山夜雨时i1 分钟前
394. 字符串解码【中等】
java·数据结构·算法·leetcode
haing20193 分钟前
使用黄金分割法计算Bezier曲线曲率极值的方法介绍
算法·黄金分割
leoufung9 分钟前
LeetCode 230:二叉搜索树中第 K 小的元素 —— 从 Inorder 遍历到 Order Statistic Tree
算法·leetcode·职场和发展
jyyyx的算法博客11 分钟前
多模字符串匹配算法 -- 面试题 17.17. 多次搜索
算法
da_vinci_x13 分钟前
Sampler AI + 滤波算法:解决 AIGC 贴图“噪点过剩”,构建风格化 PBR 工业管线
人工智能·算法·aigc·材质·贴图·技术美术·游戏美术
惊鸿.Jh15 分钟前
503. 下一个更大元素 II
数据结构·算法·leetcode
chao18984421 分钟前
MATLAB 实现声纹识别特征提取
人工智能·算法·matlab
zhishidi23 分钟前
推荐算法之:GBDT、GBDT LR、XGBoost详细解读与案例实现
人工智能·算法·推荐算法
货拉拉技术24 分钟前
货拉拉RAG优化实践:从原始数据到高质量知识库
数据库·算法
AKDreamer_HeXY34 分钟前
ABC434E 题解
c++·算法·图论·atcoder