leetcode56 合并区间

一、问题描述

二、解题思路

可以使用自定义排序+依次合并的方法来解决这个问题。

(1)首先,对intervals向量进行排序,重写比较器,按照区间左边界从小到大排序,使得有重叠区域的区间相邻;

(2)start和end用于记录当前区间之前的上一合并完的区间的情况

<1>如果当前区间和它有重叠部分,就进行一个合并;

<2>如果没有,就将start和end维护的区间加入ret,更新start和end的值;

注意:i==intervals.size()-1时,需要将现在的start和end维护的区间加入ret!!

三、代码实现

cpp 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        //排序+合并
        vector<vector<int>> ret;
        //特殊情况处理
        if(intervals.size()==0) return ret;
        //正常情况
        sort(intervals.begin(),intervals.end(),[](const vector<int>a,const vector<int>b){
            return a[0]<b[0];
        });
        //区间合并
        int start=intervals[0][0],end=intervals[0][1];//记录当前区间的左右边界
        for(int i=0;i!=intervals.size();i++){
            if(end>=intervals[i][0])
                end=max(end,intervals[i][1]);
            else if(end<intervals[i][0]){
                ret.push_back({start,end});
                start=intervals[i][0];end=intervals[i][1];
            }
            if(i==intervals.size()-1)
                ret.push_back({start,end});
        }
        return ret;
    }
};
相关推荐
先吃饱再说9 小时前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天9 小时前
C++ 基础入门完全指南
c++
黄敬峰12 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术13 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六16 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术17 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize18 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法