leetcode56:合并区间

原题地址:56. 合并区间 - 力扣(LeetCode)

题目描述

复制代码
以数组 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. 排序:
    • 首先按照每个区间的起始值升序排序,这样可以保证后续遍历时能够轻松判断区间是否重叠。
  2. 合并逻辑:
    • 使用一个临时区间 term 存储当前正在合并的区间。
    • 遍历每个区间,如果当前区间和 term 有重叠(即 term[1] >= intervals[i][0]),更新 term 的结束位置为两个区间结束位置的较大值。
    • 如果没有重叠,则将 term 加入结果集合,并用当前区间更新 term
  3. 返回结果:
    • 遍历结束后,需将最后一个 term 加入结果集合,最终返回结果。

源码实现

复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        // 边界条件:如果输入数组为空,直接返回空数组
        if (intervals.length == 0) return intervals;
        
        // 1. 对二维数组按起始值(第一列)升序排序
        Arrays.sort(intervals, (a, b) -> a[0] - b[0]);
        
        // 2. 创建结果列表用于存储合并后的区间
        List<int[]> list = new ArrayList<>();
        
        // 初始化一个临时区间,先取排序后的第一个区间
        int[] term = intervals[0];
        
        // 3. 遍历剩余区间,判断是否需要合并
        for (int i = 1; i < intervals.length; i++) {
            if (term[1] >= intervals[i][0]) { 
                // 如果当前区间和临时区间有重叠,更新临时区间的结束位置
                term[1] = Math.max(term[1], intervals[i][1]);
            } else {
                // 如果当前区间与临时区间无重叠,将临时区间加入结果集
                list.add(term);
                // 更新临时区间为当前区间
                term = intervals[i];
            }
        }
        
        // 最后一个临时区间加入结果集
        list.add(term);
        
        // 4. 将结果列表转换为二维数组返回
        return list.toArray(new int[list.size()][2]);
    }
}

复杂度分析

  1. 时间复杂度:

    • 排序部分: 使用 Arrays.sort() 对二维数组排序,时间复杂度为 O(nlog⁡n)O(nlogn),其中 nn 为区间的个数。
    • 遍历部分: 遍历所有区间进行合并操作,时间复杂度为 O(n)O(n)。
    • 总体时间复杂度: O(nlog⁡n)O(nlogn)。
  2. 空间复杂度:

    • 结果集: 使用 ArrayList 存储合并结果,空间复杂度为 O(n)O(n),其中 nn 为区间的个数。
    • 排序的辅助空间: 内部排序实现通常为原地排序,额外空间复杂度为 O(1)O(1)。
    • 总体空间复杂度: O(n)O(n)。
相关推荐
m0_629494732 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户2 小时前
用队列实现栈
数据结构·算法
做人求其滴2 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7772 小时前
记一组无人机IMU传感器数据
算法
计算机安禾2 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室3 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-3 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~3 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界3 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构
阿文的代码库3 小时前
一文读懂GROUP BY 1,2 VS GROUP BY column_1, column_2 的区别
算法