插入区间

###57. 插入区间 - 力扣(LeetCode)

给你一个 无重叠的 按照区间起始端点排序的区间列表。

在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。

示例 1:

1
2
输入:intervals = [[1,3],[6,9]], newInterval = [2,5]
输出:[[1,5],[6,9]]

示例 2:

1
2
3
输入:intervals = [[1,2],[3,5],[6,7],[8,10],[12,16]], newInterval = [4,8]
输出:[[1,2],[3,10],[12,16]]
解释:这是因为新的区间 [4,8][3,5],[6,7],[8,10] 重叠。

示例 3:

1
2
输入:intervals = [], newInterval = [5,7]
输出:[[5,7]]

示例 4:

1
2
输入:intervals = [[1,5]], newInterval = [2,3]
输出:[[1,5]]

示例 5:

1
2
输入:intervals = [[1,5]], newInterval = [2,7]
输出:[[1,7]]

提示:

  • 0 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= intervals[i][0] <= intervals[i][1] <= 105
  • intervals 根据 intervals[i][0]升序 排列
  • newInterval.length == 2
  • 0 <= newInterval[0] <= newInterval[1] <= 105
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
lass Solution {
public int[][] insert(int[][] intervals, int[] newInterval) {
List<int[]> ans = new ArrayList<>();
int i = 0;
//把左边界小于等于新区间左边界的直接插入
while(i < intervals.length){
if(intervals[i][0] <= newInterval[0]){ //第一个元素小于等于待插入的直接加入到答案
ans.add(intervals[i]);
i++;
}else{
break;
}
}
//插入新区间
if(ans.isEmpty() || newInterval[0] > ans.get(ans.size()-1)[1]){ //待插入第一个元素大于答案集合最后一个元素
ans.add(newInterval); //直接加入
}else{//否则合并
ans.get(ans.size()-1)[1] = Math.max(ans.get(ans.size()-1)[1], newInterval[1]);
}
//剩下的合并或加入
while(i < intervals.length){
if(intervals[i][0] > ans.get(ans.size()-1)[1]){
ans.add(intervals[i]);
}else{
ans.get(ans.size()-1)[1] = Math.max(ans.get(ans.size()-1)[1], intervals[i][1]);
}
i++;
}

return ans.toArray(new int[ans.size()][0]);
}
}

插入区间
http://example.com/2023/03/01/算法/贪心/15. 插入区间/
作者
PALE13
发布于
2023年3月1日
许可协议