LeetCode-56-合并区间
# LeetCode-56-合并区间
给出一个区间的集合,请合并所有重叠的区间。
示例1:
输入: [[1,3],[2,6],[8,10],[15,18]]
输出: [[1,6],[8,10],[15,18]]
解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
1
2
3
2
3
1
2
3
2
3
示例2:
输入: [[1,4],[4,5]]
输出: [[1,5]]
解释: 区间 [1,4] 和 [4,5] 可被视为重叠区间。
1
2
3
2
3
1
2
3
2
3
# 解题思路
方法1、排序+双指针:
虽然示例中没有给出需要排序的案例,但需要考虑数组不是按照首位数组顺序排列的情况,这样会让区间难以判断,所以先做一个排序。
之后初始化双指针,指向第一个区间的start和end
进入for循环判断,判断下一个区间的首位是否大于上个区间的末尾
如果大于,则说明区间分离,加入新区间{start,end},更新start
当下一个区间不大于end,即<=end的时候,区间均要进行合并,此时区间为上一个区间的start,到当前区间和下一个区间end的最大值,所以end = Math.max(end,intervals[i][1])
由于开始的start和end是上一个区间的结果,所以在最后一次时,暂时不会添加区间,res.add(new int[]{start,end});
为最后一次添加之后转化为int[][]
返回即可
# Java代码
class Solution {
public int[][] merge(int[][] intervals) {
int len = intervals.length;
if (intervals == null || len <= 1) return intervals;
List<int[]> res = new ArrayList<>();
Arrays.sort(intervals, (x, y) -> x[0] - y[0]);
int start = intervals[0][0];
int end = intervals[0][1];
for (int i = 1; i < len; i++) {
if(intervals[i][0]>end){
res.add(new int[]{start,end});
start = intervals[i][0];
}
end = Math.max(end,intervals[i][1]);
}
// 最后一次添加
res.add(new int[]{start,end});
return res.toArray(new int[res.size()][2]);
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
编辑 (opens new window)
上次更新: 2022/11/18, 11:15:10
- 01
- SpringCache基本配置类05-16
- 03
- Rpamis-security-原理解析12-13