56. 合并区间

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间

示例 1:

复制代码
输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

示例 2:

复制代码
输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

提示:

  • 1 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104
cpp 复制代码
class Solution {
public:
    static bool cmp(const vector<int>& p1,const vector<int>& p2){
        return p1[0] < p2[0];
    }
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        //合并区间,按左边界排序,不断更新有边界
        sort(intervals.begin(),intervals.end(),cmp);
        vector<vector<int>>res;
        if(intervals.size() == 0) return res;
        res.push_back(intervals[0]); //先把第一个加进去,起到pre的作用.同时利于inter[1]比较
        for(int i = 1;i < intervals.size();i++){
            if(res.back()[1] >= intervals[i][0]){
                res.back()[1] = max(res.back()[1],intervals[i][1]);
            }
            else{
                res.push_back(intervals[i]);
            }
        }
        return res;
    }
};
相关推荐
故事和你9130 分钟前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i1 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪
paeamecium1 小时前
【PAT甲级真题】- String Subtraction (20)
数据结构·c++·算法·pat考试·pat
YL200404261 小时前
047从前序与中序遍历序列构造二叉树
算法·leetcode
极梦网络无忧1 小时前
password_hash
算法·哈希算法
计算机安禾2 小时前
【c++面向对象编程】第25篇:仿函数(函数对象):重载operator()
开发语言·c++·算法
周末也要写八哥2 小时前
在C++中使用预定义宏
开发语言·c++·算法
学会870上岸华师3 小时前
C 语言程序设计——第一章课后编程题
c语言·开发语言·学习·算法
小小编程路3 小时前
新手快速学 Python 极简速成指南
开发语言·c++·python
小马过河R3 小时前
RAG检索优化策略:系统性四层框架解析
人工智能·python·算法·ai·llm·rag·问答