Day36 贪心算法 part05 435. 无重叠区间 763. 划分字母区间 56. 合并区间

贪心算法 part05 435. 无重叠区间 763. 划分字母区间 56. 合并区间

435. 无重叠区间

复制代码
class Solution {
private:
    bool static Compare(const vector<int>& a, const vector<int>& b){
        return a[0] <b[0];
    }
public:
    int eraseOverlapIntervals(vector<vector<int>>& intervals) {
        sort(intervals.begin(),intervals.end());
        int result = 0;
        for(int i = 0; i<intervals.size()-1;i++){
            if(intervals[i][1]>intervals[i+1][0]) 
            {
                result++;
                intervals[i+1][1] = min(intervals[i][1],intervals[i+1][1]);
            }
        }
        return result;
    }
};

763. 划分字母区间

复制代码
class Solution {
public:
    vector<int> partitionLabels(string S) {
        int hash[26] = {0}; // i为字符,hash[i]为字符出现的最后位置
        for (int i = 0; i < S.size(); i++) { // 统计每一个字符最后出现的位置
            hash[S[i] - 'a'] = i;
        }
        vector<int> result;
        int left = 0;
        int right = 0;
        for (int i = 0; i < S.size(); i++) {
            right = max(right, hash[S[i] - 'a']); // 找到字符出现的最远边界
            if (i == right) {
                result.push_back(right - left + 1);
                left = i + 1;
            }
        }
        return result;
    }
};

56. 合并区间

复制代码
class Solution {
private:
    bool static Compare(const vector<int>& a, const vector<int>& b){
        return a[0] <b[0];
    }    
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        vector<vector<int>> result;
        sort(intervals.begin(),intervals.end(),Compare);
        result.push_back(intervals[0]);
        for(int i =1 ; i<intervals.size();i++){
            if(intervals[i][0]<=result.back()[1]){ //重叠
                result.back()[1] = max(result.back()[1], intervals[i][1]);
            }else result.push_back(intervals[i]);
        }
        return result;
    }
};
相关推荐
励志不掉头发的内向程序员24 分钟前
STL库——string(类函数学习)
开发语言·c++
图灵学术计算机论文辅导43 分钟前
论文推荐|迁移学习+多模态特征融合
论文阅读·人工智能·深度学习·计算机网络·算法·计算机视觉·目标跟踪
threejs源码翻译官1 小时前
显微镜图像处理【优化】- 使用图像风格迁移技术放大图像细节
算法
强德亨上校2 小时前
贪心算法(Greedy Algorithm)详解
算法·贪心算法
浮灯Foden3 小时前
算法-每日一题(DAY13)两数之和
开发语言·数据结构·c++·算法·leetcode·面试·散列表
淡海水3 小时前
【原理】Struct 和 Class 辨析
开发语言·c++·c#·struct·class
西工程小巴3 小时前
实践笔记-VSCode与IDE同步问题解决指南;程序总是进入中断服务程序。
c语言·算法·嵌入式
Tina学编程4 小时前
48Days-Day19 | ISBN号,kotori和迷宫,矩阵最长递增路径
java·算法
Moonbit4 小时前
MoonBit Perals Vol.06: MoonBit 与 LLVM 共舞 (上):编译前端实现
后端·算法·编程语言
青草地溪水旁4 小时前
UML函数原型中stereotype的含义,有啥用?
c++·uml