LeetCode hot100-14

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

这道题也没什么思路,看了提示做出来的,但是还是超时了,能过167/170的案例。把排序那改成更快的排序应该就不会超时。官方解法的代码写得有一种Java水平过高,明显不是我能写出的代码的感觉。

我的代码

java 复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        int n = intervals.length;
        for (int i = 0; i < n - 1; i++) {
            for (int j = 0; j < n - i - 1; j++) {
                if (intervals[j][0] > intervals[j + 1][0]) {
                    int[] temp = intervals[j];
                    intervals[j] = intervals[j + 1];
                    intervals[j + 1] = temp;
                }
            }
        }

        int[][] res = new int[n][n];
        res[0] = intervals[0];
        int k = 0;
        for (int i = 1; i < n; i++) {
            if (intervals[i][0] > res[k][1]) {
                res[++k] = intervals[i];
            } else {
                res[k][1] = Math.max(res[k][1], intervals[i][1]);
            }
        }
        int[][] res2 = new int[k+1][k+1];
        for (int i = 0; i <= k; i++) {
            res2[i]=res[i];
        }
        return res2;

    }
}

官方解法

思路

我们用数组 merged 存储最终的答案。

首先,我们将列表中的区间按照左端点升序排序。然后我们将第一个区间加入 merged 数组中,并按顺序依次考虑之后的每个区间:

复制代码
如果当前区间的左端点在数组 merged 中最后一个区间的右端点之后,那么它们不会重合,我们可以直接将这个区间加入数组 merged 的末尾;

否则,它们重合,我们需要用当前区间的右端点更新数组 merged 中最后一个区间的右端点,将其置为二者的较大值。

需要学习的地方

排序一定要用Arrays.sort,像这种数据类型的,要自己重写compare方法。一定要学习,万分重要。下面的那个排序看着有点奇怪。是用了Lambda表达式,即函数式编程,是 JDK8 的一个新特性。 Lambda表达式允许将一个函数作为另外一个函数的参数。注意看这段代码的括号是怎么打的,compare方法是sort方法的一个参数中的一部分。

然后就是在定义返回结果的类型时,其实不知道结果数组的长度,是动态数组。这里也不太好处理,官方解法是用的list,然后再转成数组。

int[][]类型的在用toArray的时候是这样的merged.toArray(new int[merged.size()][]);

add的时候是这样的merged.add(new int[]{L, R});

List定义的类型是ArrayList<int[]>();内层还是一个数组。我之前还想过用ArrayList();真是疯了。

java 复制代码
class Solution {
    public int[][] merge(int[][] intervals) {
        if (intervals.length == 0) {
            return new int[0][2];
        }
        Arrays.sort(intervals, new Comparator<int[]>() {
            public int compare(int[] interval1, int[] interval2) {
                return interval1[0] - interval2[0];
            }
        });
        List<int[]> merged = new ArrayList<int[]>();
        for (int i = 0; i < intervals.length; ++i) {
            int L = intervals[i][0], R = intervals[i][1];
            if (merged.size() == 0 || merged.get(merged.size() - 1)[1] < L) {
                merged.add(new int[]{L, R});
            } else {
                merged.get(merged.size() - 1)[1] = Math.max(merged.get(merged.size() - 1)[1], R);
            }
        }
        return merged.toArray(new int[merged.size()][]);
    }
}

作者:力扣官方题解
链接:https://leetcode.cn/problems/merge-intervals/solutions/203562/he-bing-qu-jian-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关推荐
望舒513几秒前
代码随想录day25,回溯算法part4
java·数据结构·算法·leetcode
C++ 老炮儿的技术栈16 分钟前
Qt 编写 TcpClient 程序 详细步骤
c语言·开发语言·数据库·c++·qt·算法
KYGALYX20 分钟前
逻辑回归详解
算法·机器学习·逻辑回归
铉铉这波能秀29 分钟前
LeetCode Hot100数据结构背景知识之集合(Set)Python2026新版
数据结构·python·算法·leetcode·哈希算法
参.商.29 分钟前
【Day 27】121.买卖股票的最佳时机 122.买卖股票的最佳时机II
leetcode·golang
踢足球092932 分钟前
寒假打卡:2026-2-8
数据结构·算法
IT猿手42 分钟前
基于强化学习的多算子差分进化路径规划算法QSMODE的机器人路径规划问题研究,提供MATLAB代码
算法·matlab·机器人
千逐-沐风43 分钟前
SMU-ACM2026冬训周报3rd
算法
铉铉这波能秀1 小时前
LeetCode Hot100数据结构背景知识之元组(Tuple)Python2026新版
数据结构·python·算法·leetcode·元组·tuple
晚霞的不甘1 小时前
Flutter for OpenHarmony 实现计算几何:Graham Scan 凸包算法的可视化演示
人工智能·算法·flutter·架构·开源·音视频