文章目录
1、题目描述
合并区间。
以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

2、思路
这里我参考题解。先将intervals按照左端点进行升序排序,固定住左边,然后遍历不断更新右边的区间即可。
代码
python
class Solution:
def merge(self, intervals: List[List[int]]) -> List[List[int]]:
# step1: 将intervals里面的每个子list按照第一个元素进行升序排序
intervals.sort(key=lambda x:x[0])
# step2: 压入第一个区间
ans = [intervals[0]]
for curlist in intervals[1:]:
# case1: 若curlist的左端点在当前最后一个节点的中间
# 则update右侧的较大值
if curlist[0] >= ans[-1][0] and curlist[0] <= ans[-1][1]:
ans[-1][1] = max(curlist[1], ans[-1][1])
# case2: 若没有重合,则直接压入最终结果即可。
else:
ans.append(curlist)
return ans