【leetcode】合并区间
题目:
给出一个区间的集合,请合并所有重叠的区间。
示例 1:
输入: [[1,3],[2,6],[8,10],[15,18]]
输出: [[1,6],[8,10],[15,18]]
解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
示例 2:
输入: [[1,4],[4,5]]
输出: [[1,5]]
解释: 区间 [1,4] 和 [4,5] 可被视为重叠区间。
思路:
先将数组按照行的第第一个元素升序排列。
比较相邻的数组a[1,4]和b[2,5],当b[0]<=a[1]时,两个数组表示的范围存在重合,数组的左值一定是a[0](更小的值做范围起点),而右值则为a[1] b[1]二者中更大的值。
java代码:
class Solution {
public int[][] merge(int[][] intervals) {
List<int[]> res = new ArrayList<>();
Arrays.sort(intervals, (a,b)->a[0]-b[0]);
int i=0;
while (i<intervals.length) {
int left = intervals[i][0];
int right = intervals[i][1];
//可能有连续的不止两个数组重合,所以用while循环
i++;
while (i<intervals.length&&intervals[i][0]<=right) {
right = Math.max(right, intervals[i][1]);
i++;
}
res.add(new int[]{left, right});
}
return res.toArray(new int[0][]);
}
}