LeetCode56.合并区间

题目

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

示例

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

思路

合并重叠区间的一种常见思路是通过排序和遍历来实现:

  • 首先,将给定的区间集合按照区间的起始位置进行排序。这样做的目的是为了方便后续的合并操作。

  • 初始化一个空的结果集,用于存储合并后的区间。

  • 遍历排序后的区间集合。对于每个区间,分为两种情况进行处理:

    • 如果当前结果集为空,或者当前区间与结果集中最后一个区间无重叠(即当前区间的起始位置大于结果集中最后一个区间的结束位置),则将当前区间直接加入结果集。

    • 否则,说明当前区间与结果集中最后一个区间存在重叠。此时,更新结果集中最后一个区间的结束位置,使其变为当前区间的结束位置和原始结束位置中的较大值。

  • 遍历结束后,得到的结果集即为合并后的不重叠区间数组。

这种方法的时间复杂度主要取决于排序的时间复杂度,通常为 O(nlogn),其中 n 是区间的个数。遍历区间的时间复杂度为 O(n)。因此,整体的时间复杂度为 O(nlogn)。

Code:

c 复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        // 首先按照区间起始位置进行排序
        sort(intervals.begin(), intervals.end(), [](const vector<int>& a, const vector<int>& b) {
            return a[0] < b[0];
        });
        
        vector<vector<int>> result;
        for (const vector<int>& interval : intervals) {
            // 如果当前结果集为空,或者当前区间与结果集中最后一个区间无重叠,则将当前区间加入结果集
            if (result.empty() || interval[0] > result.back()[1]) {
                result.push_back(interval);
            } else {
                // 否则,更新结果集中最后一个区间的结束位置
                result.back()[1] = max(result.back()[1], interval[1]);
            }
        }
        
        return result;
    }
};
相关推荐
炸膛坦客11 小时前
嵌入式 - 数据结构与算法:(1-7)数据结构 - 顺序表和链表的对比
数据结构·链表
Jasmine_llq11 小时前
《B3867 [GESP202309 三级] 小杨的储蓄》
算法·循环遍历·数组累加(模拟)·索引定位·顺序输出
啦啦啦_999911 小时前
案例之 逻辑回归_电信用户流失预测
算法·机器学习·逻辑回归
风筝在晴天搁浅11 小时前
快手/字节 CodeTop LeetCode 415.字符串相加
算法·leetcode
小黄人软件11 小时前
C++读写编辑CSV文件示例源码 用于数据导入导出,比Excel好使
开发语言·c++·excel
郭涤生12 小时前
C++各个版本的性能和安全性总结
开发语言·c++
hoiii18712 小时前
基于栅格法的机器人工作空间划分系统
数据结构·机器人
DragonnAi12 小时前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法
算法·开源
机器视觉_Explorer12 小时前
【halcon】编程技巧:鼠标擦除
图像处理·人工智能·深度学习·算法·视觉检测
wljy113 小时前
二、静态库的制作和使用
linux·c语言·开发语言·c++