问题描述:
以数组 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 <= intervals.length <= 104
intervals[i].length == 2
0 <= starti <= endi <= 1
上代码拿去即可运行:
package com.onlyqi.daydayup.leetcode;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class Test01 {
public static void main(String[] args) {
int[][] array = new int[][]{{1, 3},
{2, 6},
{8, 10},
{15, 18}};
int[][] result= merge(array);
for (int i = 0; i < result.length; i++) {
for (int i1 = 0; i1 < result[i].length; i1++) {
System.out.print(result[i][i1] + " ");
}
System.out.println();
}
}
public static int[][] merge(int[][] intervals) {
if (intervals.length <= 1) {
return intervals;
}
Arrays.sort(intervals, (a, b) -> Integer.compare(a[0], b[0]));
List<int[]> list = new ArrayList<>();
int[] curr = intervals[0];
list.add(curr);
for (int[] interval : intervals) {
int currEnd = curr[1];
int nextStart = interval[0];
int nextEnd = interval[1];
if (currEnd >= nextStart) {
// 有重叠,合并
curr[1] = Math.max(currEnd, nextEnd);
} else {
// 无重叠,直接加入
curr = interval;
list.add(curr);
}
}
int[][] result = list.toArray(new int[list.size()][]);
return result;
}
}
运行结果:
我要刷300道算法题,第141道 。 希望自己可以坚持下去 。