代码随想录打卡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;
    }
};
相关推荐
浦信仿真大讲堂20 分钟前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠30 分钟前
PCL 生成三棱锥点云
c++·算法·最小二乘法
代码中介商38 分钟前
跳表:高效查找的链表黑科技
数据结构
兰令水41 分钟前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇1 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法
玉小格1 小时前
一次关于Python的总结
算法
伊甸31 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
bIo7lyA8v1 小时前
算法中的随机化思想及其复杂度收益评估的技术8
算法
数据法师1 小时前
视频文件重复检测工具:基于哈希与视频指纹的三级筛选机制
算法·音视频·哈希算法
其实防守也摸鱼2 小时前
软件安全与漏洞--Windows底层原理与软件逆向工程基础
linux·网络·数据库·算法·安全·安全架构·软件安全与漏洞