【手撕真题】合并区间

题目意思很好理解:

给定一个区间集合,每个区间由 [start, end] 组成,要求合并所有重叠的区间,返回一个不重叠的区间数组,且这个数组要恰好覆盖输入中的所有区间。

思路

首先,先按每个区间的起始值从小到大排序,这样重叠的区间就会挨在一起,方便后续合并;

然后初始化一个结果列表,把排序后的第一个区间放进去,作为初始的待合并区间;

接着遍历剩下的所有区间,每次取出结果列表的最后一个区间和当前区间比较:

如果当前区间的起始值小于等于最后一个区间的结束值,说明两个区间重叠,就把最后一个区间的结束值更新为两者的最大值,完成合并;

如果不重叠,就直接把当前区间加入结果列表;

最后把结果列表转换成二维数组返回即可。

代码实现

java 复制代码
    public int[][] merge(int[][] intervals) {
        // 区间个数为0或1,直接返回
        if (intervals.length <= 1) {
            return intervals;
        }

        // 1. 按区间的start值从小到大排序
        // a[0]-b[0]表示按start升序
        Arrays.sort(intervals, (a, b) -> a[0] - b[0]);

        // 2. 初始化结果列表,存储合并后的区间
        List<int[]> res = new ArrayList<>();
        // 先将排序后的第一个区间加入结果列表,作为初始合并区间
        res.add(intervals[0]);

        // 3. 遍历剩下的所有区间,逐个合并
        for (int i = 1; i < intervals.length; i++) {
            // 取出结果列表中最后一个区间
            int[] last = res.get(res.size() - 1);
            // 取出当前遍历的区间
            int[] curr = intervals[i];

            // 判断是否重叠:当前区间的start <= 最后一个区间的end
            if (curr[0] <= last[1]) {
                // 重叠:合并区间,更新最后一个区间的end为两者最大值
                last[1] = Math.max(last[1], curr[1]);
            } else {
                // 不重叠:直接将当前区间加入结果列表
                res.add(curr);
            }
        }

        // 4. 将List<int[]>转换为int[][]
        return res.toArray(new int[res.size()][]);
    }
相关推荐
Godspeed Zhao2 分钟前
从零开始学AI16——SVM
算法·机器学习·支持向量机
江屿风13 分钟前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法
nebula-AI14 分钟前
人工智能导论:模型与算法(核心技术)
人工智能·深度学习·神经网络·算法·机器学习·集成学习·sklearn
运筹vivo@32 分钟前
LeetCode 2405. 子字符串的最优划分
c++·算法·leetcode·职场和发展·哈希表
数智工坊33 分钟前
视觉-语言-动作模型解剖学:从模块、里程碑到核心挑战
论文阅读·人工智能·深度学习·算法·transformer
有点。1 小时前
C++(枚举法一练习题)
开发语言·c++·算法
黎阳之光1 小时前
视听融合新范式!黎阳之光打破视觉边界,声影协同赋能全域智慧管控
大数据·人工智能·物联网·算法·数字孪生
玖釉-2 小时前
栈——栈的定义及基本操作
c++·windows·算法·图形渲染
ゆづき2 小时前
Java 初学者入门指南:常见问题 + 核心知识点 + 进阶 20 道练习题
java·开发语言·学习·算法·水题
Evand J3 小时前
【课题推荐】强跟踪UKF算法,三维非线性状态量和观测量,附MATLAB代码测试结果
开发语言·算法·matlab