代码随想录第31天:贪心

56. 合并区间

复制代码
class Solution {
public:
    static bool cmp(vector<int> &a,vector<int> &b)
    {
        return a[0]<b[0];
    }
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        if(intervals.size()==1)
        {
            return intervals;
        }
        
        vector<vector<int>> res;
        sort(intervals.begin(),intervals.end(),cmp);
        res.push_back(intervals[0]);
        for(int i=1;i<intervals.size();i++)
        {
            
            if(intervals[i][0]<=res.back()[1])
            {
                res.back()[1]=max(intervals[i][1],res.back()[1]);
            }
            else
            {
                res.push_back(intervals[i]);
            }
            
        }
        return res;
    }
};
  • result.back():返回 result 向量的最后一个元素的引用(类型为 vector<int>&,即最后一个区间)。

  • result.back()[1]:通过引用访问该区间的第二个整数,也就是右边界(索引从0开始,所以 [1] 代表右端点)。这个表达式返回一个 int&,意味着我们可以直接修改这个值。

这道题目的关键是知道合并区间怎么学,res.back()[1]

738. 单调递增的数字

复制代码
class Solution {
public:
    int monotoneIncreasingDigits(int n) {
        string s=to_string(n);
        int flag=s.size();
        for(int i=s.size()-1;i>0;i--)
        {
            if(s[i-1]>s[i])
            {
                s[i-1]--;
                flag=i;
            }
        }
        for(int i=flag;i<s.size();i++)
        {
            s[i]='9';
        }
        return stoi(s);
    }
};

这道题目的关键是要找到最后一个数字减一的位置,把后面的位置进行标记,后面的全部变成9

还要记住to---string和stoi这两个函数

相关推荐
帅小伙―苏3 分钟前
力扣42接雨水
前端·算法·leetcode
AI科技星19 分钟前
精细结构常数α的几何本源:从第一性原理的求导证明、量纲分析与全域验证
算法·机器学习·数学建模·数据挖掘·量子计算
6Hzlia24 分钟前
【Hot 100 刷题计划】 LeetCode 287. 寻找重复数 | C++ 数组判环 (快慢指针终极解法)
c++·算法·leetcode
MegaDataFlowers25 分钟前
26.删除有序数组中的重复项
算法
故事和你912 小时前
洛谷-数据结构1-4-图的基本应用2
开发语言·数据结构·算法·深度优先·动态规划·图论
吴可可1232 小时前
C#合并首尾相连多段线实战
算法·c#
KMDxiaozuanfeng3 小时前
卡梅德生物技术快报|SPR 技术应用|基于 SPR 亲和力的中药活性成分筛选系统实现与数据分析
科技·算法·面试·考试
꧁细听勿语情꧂3 小时前
数据结构概念和算法、时间复杂度、空间复杂度引入
c语言·开发语言·数据结构·算法
Felven3 小时前
B. The 67th 6-7 Integer Problem
数据结构·算法
玉树临风ives3 小时前
atcoder ABC 454 题解
算法·深度优先·图论