算法-合并区间

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

复制代码
输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

代码实现:

java 复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        // 排序
        Arrays.sort(intervals, new Comparator<int[]>() {
            public int compare(int[] arr1, int[] arr2) {
                return arr1[0] - arr2[0];
            }
        });
        // 对于 2L 1R 大小关系
        List<int[]> list = new ArrayList<>();
        for (int i = 0; i < intervals.length; i++) {
            int[] cur = intervals[i];
            if (list.isEmpty()) {
                list.add(cur);
            } else if (cur[0] <= list.get(list.size() - 1)[1]) {
                list.get(list.size() - 1)[1] = 
                    Math.max(cur[1], list.get(list.size() - 1)[1]);
            } else {
                list.add(cur);
            }
        }
        return list.toArray(new int[list.size()][]);
    }
}

原题链接:力扣

视频讲解链接:合并区间_哔哩哔哩_bilibili

相关推荐
WL_Aurora8 小时前
Python 算法基础篇之元组与列表
python·算法
Brilliantwxx8 小时前
【算法题】递归树+哈希表+分治异或+双指针
开发语言·c++·笔记·算法
yugi9878388 小时前
经典三维表面重建算法(C语言实现)
c语言·开发语言·算法
无限进步_8 小时前
【C++】智能指针族谱:auto_ptr、unique_ptr、shared_ptr
java·开发语言·数据结构·c++·算法
Brilliantwxx8 小时前
【C++】Stack和Queue(初认识和算法题OJ)
开发语言·c++·笔记·算法
fffzd8 小时前
C++入门(二)
开发语言·c++·算法·函数重载·引用·inline内联函数·nullptr
傻瓜搬砖人8 小时前
c语言绿皮书第三版第十章习题
c语言·开发语言·算法
Lazionr8 小时前
数据结构堆详解:原理、实现与应用
数据结构·算法
故事和你918 小时前
蓝桥杯-2026年C++B组省赛
开发语言·数据结构·c++·算法·蓝桥杯·动态规划·图论
星恒随风8 小时前
C语言算法复杂度详解:时间复杂度与空间复杂度一篇讲透
c语言·算法