DAY36贪心算法Ⅴ

56. 合并区间 - 力扣(LeetCode)

cpp 复制代码
class Solution {
static bool cmp(vector<int>&a,vector<int>&b){
    return a[0] < b[0];
}
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        sort(intervals.begin(),intervals.end(),cmp);
        vector<vector<int>>result;
        result.push_back(intervals[0]);
        for(int i=1;i<intervals.size();i++){
            if(result.back()[1] >= intervals[i][0]){
                result.back()[1]=max(intervals[i][1],result.back()[1]);
            }
            else{
                result.push_back(intervals[i]);
            }
        }
        return result;
    }
};

和之前做的题很像,先排序、将第一个元素放入结果中根据边界条件不断更新数组边界。

738. 单调递增的数字 - 力扣(LeetCode)

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

需要记住两个标准库函数的使用:

to_string()将数值类型转化为字符串类型。

stoi()将字符串类型转化为数值类型。

相关推荐
近津薪荼1 分钟前
递归专题(2)——合并链表
c++·学习·算法·链表
Asher阿舍技术站2 分钟前
【数字通信理论系列】四、载波相位同步
算法·载波同步
圣保罗的大教堂3 分钟前
leetcode 3013. 将数组分成最小总代价的子数组 II 困难
leetcode
划破黑暗的第一缕曙光6 分钟前
[数据结构]:6.二叉树链式结构的实现2
c语言·数据结构·二叉树
-Try hard-6 分钟前
队列 | 二叉树
算法
maplewen.7 分钟前
C++11 std::function
开发语言·c++
Sagittarius_A*8 分钟前
灰度变换与阈值化:从像素映射到图像二值化的核心操作【计算机视觉】
图像处理·人工智能·opencv·算法·计算机视觉·图像阈值·灰度变换
水饺编程17 分钟前
第4章,[标签 Win32] :文本尺寸的度量
c语言·c++·windows·visual studio
Nie_Xun17 分钟前
卡尔曼滤波(EKF/IEKF)与非线性优化(高斯-牛顿法)的统一关系
算法
蒹葭玉树20 分钟前
【C++上岸】C++常见面试题目--操作系统篇(第二十九期)
java·c++·面试