代码随想录算法训练营第三十七天| 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,一旦出现strNumi - 1 > strNumi的情况(非单调递增),首先想让strNumi - 1--,然后strNumi给为9,这样这个整数就是89,即小于98的最大的单调递增整数。也就是说,我们只需要找到最先不满足单增性质的位置,然后将前一个元素-1,后面的所有元素变为9即可。因此,代码分两步:

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

遍历数组,比较前后两个元素的大小,然后不断维护前者大于后者的最新下标。此时是从前向后遍历还是从后向前遍历呢?从前向后遍历的话,遇到strNumi - 1 > strNumi的情况,让strNumi - 1减一,但此时如果strNumi - 1减一了,可能又小于strNumi - 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.总览

相关推荐
南境十里·墨染春水2 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
@insist1232 小时前
系统架构设计师-实时性评价、调度算法与内核架构选型
算法·架构·系统架构·软考·系统架构设计师·软件水平考试
一拳一个呆瓜5 小时前
【STL】_SCL_SECURE_NO_WARNINGS
c++·stl
小小编程路5 小时前
C++ 异常 完整讲解
开发语言·c++
一只齐刘海的猫7 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏1118 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
Frank学习路上8 小时前
【C++】面试:关键字与语法特性
c++·面试
IronMurphy9 小时前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe9 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列