leetcode56:合并区间

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

示例 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 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104

步骤1:定义题目的计算问题性质

题目要求合并重叠的区间,并返回一个不重叠的区间数组,该数组需要恰好覆盖输入中的所有区间。

输入输出条件:

  • 输入:一个二维数组 intervals,每个子数组包含两个整数 [starti, endi],表示一个区间。
  • 输出:一个二维数组,表示合并后的不重叠区间。

限制条件:

  • 1 <= intervals.length <= 10^4:输入的区间数量在1到10^4之间。
  • intervals[i].length == 2:每个区间数组长度为2。
  • 0 <= starti <= endi <= 10^4:区间的起始和结束值在0到10^4之间。

潜在的边界条件:

  • 输入的区间数组可能为空。
  • 所有区间可能都不重叠。
  • 所有区间可能完全重叠。

步骤2:分解题目并描述解决方案

步骤:

  1. 对输入的区间数组按照每个区间的起始值进行排序。
  2. 遍历排序后的区间数组,比较当前区间的起始值和前一个区间的结束值。
  3. 如果当前区间的起始值小于或等于前一个区间的结束值,则它们重叠,合并这两个区间。
  4. 如果不重叠,将前一个区间加入结果数组,并继续处理下一个区间。
  5. 遍历结束后,将最后一个区间加入结果数组。

算法设计思路:

  • 采用贪心算法,因为我们可以通过局部最优(合并当前重叠区间)来达到全局最优(合并所有重叠区间)。

时间复杂度和空间复杂度:

  • 排序的时间复杂度为 O(n log n),其中 n 是区间数组的长度。
  • 遍历区间数组的时间复杂度为 O(n)。
  • 总的时间复杂度为 O(n log n)。
  • 空间复杂度为 O(1),如果忽略排序算法的空间消耗,因为合并操作是在原数组上进行的。

步骤3:C++代码实现

步骤4:通过解决该问题获得的启发

通过解决该问题,我们可以学习到:

  • 贪心算法在处理区间合并问题时的高效性。
  • 如何在遍历过程中进行合并操作,以减少空间复杂度。
  • 对输入数据进行预处理(排序)的重要性。

步骤5:实际应用

实际应用示例:

  • 在航班预订系统中,需要合并重叠的航班时间,以便为乘客提供连续的飞行时间选择。
  • 在日程管理应用中,合并不同会议的时间段,以展示用户的全天日程。

实现方法:

  • 使用上述算法对用户的日程或航班时间进行排序和合并。
  • 将合并后的时间段展示给用户,以便用户能够快速了解其全天的安排。
相关推荐
MC皮蛋侠客3 小时前
Google Test 单元测试指南
c++·单元测试·google test
艾莉丝努力练剑4 小时前
【Linux:文件】Ext系列文件系统进阶
linux·运维·服务器·c++·文件系统·文件io·ext
kkeeper~5 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs6666 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964136 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
basketball6166 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
嗝o゚7 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本7 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Fre丸子_8 小时前
自定义文件夹选取功能
c++
Ulyanov8 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真