代码随想录打卡day25:56.合并区间

题目链接:56. 合并区间 - 力扣(LeetCode)

思路:

先按左边界排序,然后开始遍历。发现有当前位置区间和前一位置区间有交集,就合并区间并存放在当前位置,这样可以方便之后遍历的下一位置i+1与当前位置i对比看是否有交集。若无交集则将当前位置i存放的区间放到res中。

代码如下:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        sort(intervals.begin(),intervals.end(),
        [](const vector<int> &a,const vector<int>&b){
            if(a[0]==b[0]){
                return a[1]<b[1];
            }
            else return a[0]<b[0];
        });
        
        vector<vector<int>> res;

        if(intervals.size()<=1) return intervals;
        
        for(int i=1;i<intervals.size();++i){
            if(intervals[i][0]<=intervals[i-1][1]){
                intervals[i][0]=min(intervals[i][0],intervals[i-1][0]);
                intervals[i][1]=max(intervals[i][1],intervals[i-1][1]);
            }
            else{
                vector<int> path={intervals[i-1][0],intervals[i-1][1]};
                res.push_back(path);
            }
            if(i==intervals.size()-1){
                res.push_back({intervals[i][0],intervals[i][1]});
            }
        }
        return res;
    }
};
相关推荐
千金裘换酒7 分钟前
Leetcode 有效括号 栈
算法·leetcode·职场和发展
空空潍23 分钟前
hot100-最小覆盖字串(day12)
数据结构·算法·leetcode
Rui_Freely32 分钟前
Vins-Fusion之 相机—IMU在线标定(十一)
人工智能·算法·计算机视觉
yyy(十一月限定版)1 小时前
算法——二分
数据结构·算法
七点半7701 小时前
c++基本内容
开发语言·c++·算法
嵌入式进阶行者1 小时前
【算法】基于滑动窗口的区间问题求解算法与实例:华为OD机考双机位A卷 - 最长的顺子
开发语言·c++·算法
嵌入式进阶行者1 小时前
【算法】用三种解法解决字符串替换问题的实例:华为OD机考双机位A卷 - 密码解密
c++·算法·华为od
罗湖老棍子1 小时前
信使(msner)(信息学奥赛一本通- P1376)四种做法
算法·图论·dijkstra·spfa·floyd·最短路算法
生成论实验室1 小时前
生成论之基:“阴阳”作为元规则的重构与证成——基于《易经》与《道德经》的古典重诠与现代显象
人工智能·科技·神经网络·算法·架构
啊董dong1 小时前
noi-2026年1月07号作业
数据结构·c++·算法·noi