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

🔥个人主页: 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 函数确保合并后的右端点是两个区间的最大值,避免出现左端点小但右端点也小的情况。
相关推荐
liulilittle5 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
色空大师5 小时前
【debug调试详解-idea】
java·ide·intellij-idea·调试·远程调试
程序猿阿越5 小时前
AutoMQ源码(一)读、写、Compaction
java·后端·源码
IronMurphy5 小时前
【算法五十七】146. LRU 缓存
算法·缓存
茉莉玫瑰花茶5 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
ywl4708120875 小时前
jwt生产token,简单版helloworld
java·数据库·spring
未若君雅裁5 小时前
生产问题排查与性能瓶颈定位:日志、监控、链路追踪、压测与Arthas
java·web安全
文艺倾年5 小时前
【强化学习】强化学习基本概念,20W字总结(一)
人工智能·python·语言模型·自然语言处理·面试·职场和发展·大模型
宸丶一5 小时前
Day 13:持久化记忆 - 让 Agent 拥有长期记忆
jvm·python·ai
器灵科技5 小时前
AI视频工具实测:Seedance/可灵/HappyHorse谁最能打?
java·运维·数据库·人工智能·github