力扣经典150题第四十八题:合并区间

目录

题目描述和要求

给定一个数组 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. 初始化一个结果列表,用于存储合并后的区间。
  3. 遍历排序后的区间,如果当前区间与结果列表中最后一个区间重叠,则更新最后一个区间的结束位置;否则,将当前区间加入结果列表。
  4. 返回结果列表。

算法实现

java 复制代码
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class MergeIntervals {
    public int[][] merge(int[][] intervals) {
        if (intervals == null || intervals.length == 0) {
            return new int[0][];
        }

        Arrays.sort(intervals, (a, b) -> a[0] - b[0]);

        List<int[]> merged = new ArrayList<>();
        for (int[] interval : intervals) {
            if (merged.isEmpty() || merged.get(merged.size() - 1)[1] < interval[0]) {
                merged.add(interval);
            } else {
                merged.get(merged.size() - 1)[1] = Math.max(merged.get(merged.size() - 1)[1], interval[1]);
            }
        }

        return merged.toArray(new int[merged.size()][]);
    }
}

复杂度分析

  • 时间复杂度:O(nlogn),其中 n 为区间的数量。排序的时间复杂度为 O(nlogn),遍历一次区间的时间复杂度为 O(n)。
  • 空间复杂度:O(logn)~O(n),取决于排序的实现方式和额外空间的使用情况。

测试和验证

编写测试用例对算法进行验证,确保其正确性和健壮性。

java 复制代码
public class Main {
    public static void main(String[] args) {
        MergeIntervals mergeIntervals = new MergeIntervals();

        int[][] intervals1 = {{1, 3}, {2, 6}, {8, 10}, {15, 18}};
        System.out.println(Arrays.deepToString(mergeIntervals.merge(intervals1))); // [[1,6],[8,10],[15,18]]

        int[][] intervals2 = {{1, 4}, {4, 5}};
        System.out.println(Arrays.deepToString(mergeIntervals.merge(intervals2))); // [[1,5]]
    }
}

总结和拓展

本题通过对区间按照起始位置进行排序,然后合并重叠的区间,实现了对给定区间的合并操作。这个算法思路清晰简单,在处理类似问题时是一个不错的选择。

此外,我们也可以考虑其他方法实现区间合并,例如使用栈或递归等方式,来实现同样的功能。

参考资料

  • 《力扣经典150题》
  • LeetCode 官方网站
相关推荐
天乐敲代码25 分钟前
JAVASE入门九脚-集合框架ArrayList,LinkedList,HashSet,TreeSet,迭代
java·开发语言·算法
十年一梦实验室30 分钟前
【Eigen教程】矩阵、数组和向量类(二)
线性代数·算法·矩阵
Kent_J_Truman31 分钟前
【子矩阵——优先队列】
算法
快手技术2 小时前
KwaiCoder-23BA4-v1:以 1/30 的成本训练全尺寸 SOTA 代码续写大模型
算法·机器学习·开源
一只码代码的章鱼2 小时前
粒子群算法 笔记 数学建模
笔记·算法·数学建模·逻辑回归
小小小小关同学2 小时前
【JVM】垃圾收集器详解
java·jvm·算法
Swift社区2 小时前
统计文本文件中单词频率的 Swift 与 Bash 实现详解
vue.js·leetcode·机器学习
圆圆滚滚小企鹅。2 小时前
刷题笔记 贪心算法-1 贪心算法理论基础
笔记·算法·leetcode·贪心算法
Kacey Huang3 小时前
YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战第十三天|YOLOv3实战、安装Typora
人工智能·算法·yolo·目标检测·计算机视觉
2401_897916843 小时前
2018 秋招 百度二轮面试---血淋淋的经历写实
面试·职场和发展