0%

LeetCode 056 Merge Intervals

Description

Given a collection of intervals, merge all overlapping intervals.

Example 1:

1
2
3
Input: [[1,3],[2,6],[8,10],[15,18]]
Output: [[1,6],[8,10],[15,18]]
Explanation: Since intervals [1,3] and [2,6] overlaps, merge them into [1,6].

Example 2:

1
2
3
Input: [[1,4],[4,5]]
Output: [[1,5]]
Explanation: Intervals [1,4] and [4,5] are considered overlapping.

Difficulty: Medium

Code:

1
2
3
4
5
class Solution {
public int[][] merge(int[][] intervals) {

}
}

题意

给定一组区间,要求合并所有重叠的区间。

Solution 1

先将区间进行排序,用每个区间的起始位置进行比较。

将第一个区间存入结果集,循环遍历所有区间。

若当前区间和结果集中最后一个区间有重叠,那么修改最后一个区间的end,其值为两个区间end的最大值。

若无重叠,则直接将当前区间存入结果集,其作为结果集中最后一个区间。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
class Solution {
public int[][] merge(int[][] intervals) {
if(intervals==null||intervals.length<2) return intervals;
Arrays.sort(intervals,(i1,i2) -> Integer.compare(i1[0],i2[0]));
List<int[]> res = new ArrayList<int[]>();
int[] newInterval = intervals[0];
res.add(newInterval);
for(int[] interval:intervals){
if(interval[0]<=newInterval[1]){
newInterval[1]=Math.max(newInterval[1],interval[1]);
}else{
newInterval = interval;
res.add(newInterval);
}
}
return res.toArray(new int[res.size()][2]);
}
}

时间复杂度: O(n)。

空间复杂度: O(n)。

Solution 2

将每个区间的起始位置和结束位置分别存入数组starts和ends,并分别对其进行排序。

令i,j起始为0,start[i+1]若比前一个位置end[i]大,说明区间不连续,可以直接{start[j],end[i]}添加到结果集。

j为上一个不连续区间的下一个位置。

注意:若区间为[[8,19],[15,18]],则starts为[8,15],ends为[19,18],那么分别排序后starts为[8,15],ends为[18,19],对结果没有影响。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class Solution {
public int[][] merge(int[][] intervals) {
if(intervals==null||intervals.length<2) return intervals;
List<int[]> res = new ArrayList<int[]>();
int[] starts = new int[intervals.length];
int[] ends = new int[intervals.length];
for(int i=0;i<intervals.length;i++){
starts[i]=intervals[i][0];
ends[i]=intervals[i][1];
}
Arrays.sort(starts);
Arrays.sort(ends);
for(int i=0,j=0;i<intervals.length;i++){
if(i==intervals.length-1||starts[i+1]>ends[i]){
res.add(new int[]{starts[j],ends[i]});
j=i+1;
}
}
return res.toArray(new int[res.size()][2]);
}
}

时间复杂度: O(n)。

空间复杂度: O(n)。