题目:

给出一个区间的集合,请合并所有重叠的区间。

示例 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][]);
    }
}

 

由于水平有限,博客中难免会有一些错误,有纰漏之处恳请各位大佬不吝赐教!


及时更新最新文章和学习资料,一起来学习:

【leetcode】合并区间_i++