普通数组----合并区间

🔥个人主页: Milestone-里程碑

❄️个人专栏: <<力扣hot100>> <<C++>><<Linux>>

<<Git>><<MySQL>>

🌟心向往之行必能至

题目描述

给定一个区间集合 intervals,其中每个区间为 [start_i, end_i]。要求合并所有重叠的区间,返回一个不重叠的区间数组,使其恰好覆盖输入中的所有区间。

示例 1 输入:intervals = [[1,3],[2,6],[8,10],[15,18]]输出:[[1,6],[8,10],[15,18]]解释:区间 [1,3][2,6] 重叠,合并为 [1,6]

示例 2 输入:intervals = [[1,4],[4,5]]输出:[[1,5]]解释:区间 [1,4][4,5] 可视为重叠区间。


解题思路

这道题的关键在于先排序,再合并

  1. 排序我们首先对区间数组按照每个区间的左端点进行升序排序。这样可以保证在后续遍历中,我们只需要关注当前区间与结果数组中最后一个区间的关系。

  2. 合并

    • 初始化一个空的结果数组 p
    • 遍历排序后的每个区间:
      • 如果结果数组为空,或者当前区间的左端点 > 结果数组最后一个区间的右端点,说明无重叠,直接将当前区间加入结果数组。
      • 否则,说明有重叠,需要合并:更新结果数组最后一个区间的右端点为两者的最大值。

完整 C++ 代码

cpp

复制代码
class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        // 按区间左端点升序排序
        sort(intervals.begin(), intervals.end());
        vector<vector<int>> p;
        for (auto& e : intervals) {
            // 如果结果为空,或当前区间与结果最后一个区间不重叠
            if (p.empty() || e[0] > p.back()[1]) {
                p.push_back(e);
            } else {
                // 重叠则合并,更新右端点为较大值
                p.back()[1] = max(p.back()[1], e[1]);
            }
        }
        return p;
    }
};

复杂度分析

  • 时间复杂度:\(O(n \log n)\),主要来自排序操作,遍历合并的时间为 \(O(n)\)。
  • 空间复杂度:\(O(n)\),主要用于存储结果数组(若忽略结果存储,排序的栈空间为 \(O(\log n)\))。

关键细节

  • 排序规则sort 默认按区间的第一个元素升序排列,这正好符合我们的需求。
  • 合并条件e[0] <= p.back()[1] 表示当前区间与结果最后一个区间有重叠或相邻。
  • 右端点更新 :使用 max 函数确保合并后的右端点是两个区间的最大值,避免出现左端点小但右端点也小的情况。
相关推荐
2601_95613942几秒前
文旅行业品牌全案公司哪家强
大数据·人工智能·python
hrhcode1 分钟前
【LangGraph】二.State 和 Node 的设计细节
python·ai·langchain·langgraph·ai框架
新新学长搞科研1 分钟前
【高质量能源会议推荐】第十一届能源与环境研究进展国际学术会议(ICAEER 2026)
人工智能·物联网·算法·机器学习·能源·环境·新能源
逝水如流年轻往返染尘4 分钟前
JAVA中的String类
java
一只叫煤球的猫6 分钟前
ThreadForge 1.2.0 发布:让 Java 并发代码更好写,这次补齐了高阶编排、示例与观测能力
java·设计模式·设计
dfdfadffa11 分钟前
如何创建仅在首次订阅时执行一次计算的 RxJS 懒加载 Observable
jvm·数据库·python
counting money12 分钟前
Spring框架基础(依赖注入-半注解形式)
java·后端·spring
CN-Dust13 分钟前
【C++】for循环例题专题
java·c++·算法
m0_6245785914 分钟前
SQL分组后如何计算移动平均值_利用窗口函数AVG配合ROWS
jvm·数据库·python