代码随想录打卡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;
    }
};
相关推荐
自由生长20243 小时前
科普-BOM是什么?和UTF-8什么关系?
算法
小年糕是糕手3 小时前
【数据结构】常见的排序算法 -- 插入排序
c语言·开发语言·数据结构·学习·算法·leetcode·排序算法
墨染点香4 小时前
LeetCode 刷题【142. 环形链表 II】
算法·leetcode·链表
海琴烟Sunshine4 小时前
leetcode 263. 丑数 python
python·算法·leetcode
信仰_2739932434 小时前
Guava Cache淘汰算法
算法·guava
散峰而望4 小时前
C++入门(二) (算法竞赛)
开发语言·c++·算法·github
Cx330❀4 小时前
《C++ 搜索二叉树》深入理解 C++ 搜索二叉树:特性、实现与应用
java·开发语言·数据结构·c++·算法·面试
不染尘.5 小时前
2025_11_5_刷题
开发语言·c++·vscode·算法·贪心算法·动态规划
2501_929177585 小时前
C++中的虚基类
开发语言·c++·算法