代码随想录算法训练营Day35 | 435. 无重叠区间 763.划分字母区间 56. 合并区间

代码随想录算法训练营Day35 | 435. 无重叠区间 763.划分字母区间 56. 合并区间

LeetCode 435. 无重叠区间

题目链接:LeetCode 435. 无重叠区间

思路:

左排序,统计 重合区域,并记录右区间最小值

cpp 复制代码
class Solution {
public:

    bool static cmp(vector<int>& a , vector<int>& b){
        //if(a[0] == b[0]) return a[1] < b[1];
        return a[0] < b[0];
    }
    int eraseOverlapIntervals(vector<vector<int>>& intervals) {
        if(intervals.size()==1) return 0;
        sort(intervals.begin(), intervals.end());
        int count = 0;
        for(int i = 1; i<intervals.size(); i++){
            if(intervals[i][0] < intervals[i-1][1]) {
                count++;
                intervals[i][1] = min(intervals[i][1], intervals[i-1][1]);
            }
            
        }
        return count;
    }
};

注意 :

  1. 注意是在重叠时判断右区间的最小值

LeetCode 763.划分字母区间

题目链接:LeetCode 763.划分字母区间

思路:

用hash表记录最右区间,再滑动最右区间即可。

cpp 复制代码
class Solution {
public:
    vector<int> partitionLabels(string s) {
        int hash[]27,0);
        vector<int> res;
        for(int i=0; i<s.size(); i++){
            hash[s[i]-'a'] = i;
        }

        int left = 0;
        int right = 0;
        for(int i=0; i < s.size(); i++){
            right = max(hash[s[i]-'a'], right);
            if(i==right){
                res.push_back(right-left+1);
                left = i+1;
            }
        }
        return res;
    }
};

注意 :

  1. 需要单独一个index遍历数组

LeetCode 56. 合并区间

题目链接:LeetCode 56. 合并区间

思路:

左区间排序,变化右区间,取最大值

cpp 复制代码
class Solution {
public:
    bool static cmp (vector<int>& a, vector<int>& b){
        return a[0] < b[0];
    }
    vector<vector<int>> merge(vector<vector<int>>& intervals) {

        vector<vector<int>> res;
        sort(intervals.begin(), intervals.end(), [](vector<int>& a, vector<int>& b){return a[0] < b[0];});
        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;
    }
};

注意 :

  1. 可用lambda表达式写cmp函数
相关推荐
CoovallyAIHub7 分钟前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub2 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub2 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞2 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕3 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub4 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub5 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉
zone77395 小时前
002:RAG 入门-LangChain 读取文本
后端·算法·面试