-
Notifications
You must be signed in to change notification settings - Fork 2
/
MergeIntervals.java
66 lines (57 loc) · 1.85 KB
/
MergeIntervals.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package Leetcode;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
/**
* @author kalpak
*
* Given an array of intervals where intervals[i] = [starti, endi], merge all overlapping intervals, and return an array of the non-overlapping intervals that cover all the intervals in the input.
*
*
*
* Example 1:
*
* Input: intervals = [[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:
*
* Input: intervals = [[1,4],[4,5]]
* Output: [[1,5]]
* Explanation: Intervals [1,4] and [4,5] are considered overlapping.
*
*
* Constraints:
*
* 1 <= intervals.length <= 104
* intervals[i].length == 2
* 0 <= starti <= endi <= 104
*
*/
public class MergeIntervals {
public static int[][] merge(int[][] intervals) {
if(intervals.length <= 1)
return intervals;
List<int []> result = new ArrayList<>();
// Sort on the basis of the start element of each interval
Arrays.sort(intervals, (a, b) -> a[0] - b[0]);
// Add the first interval to the list and then check for overlaps
result.add(intervals[0]);
int[] currentInterval = intervals[0];
for(int i = 1; i < intervals.length; i++) {
if(intervals[i][0] <= currentInterval[1])
currentInterval[1] = Math.max(currentInterval[1], intervals[i][1]);
else {
currentInterval = intervals[i];
result.add(intervals[i]);
}
}
return result.toArray(new int[result.size()][]);
}
public static void main(String[] args) {
int[][] intervals = new int[][]{{1, 3}, {2, 6}, {8, 10}, {15, 18}};
int[][] result = merge(intervals);
for(int[] i: result)
System.out.print("["+i[0] + " " +i[1] + "], ");
}
}