文章目录
- 1、题目描述
- 2、思路
- 代码
1、题目描述
合并区间。
以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。
2、思路
这里我参考题解。先将intervals按照左端点进行升序排序,固定住左边,然后遍历不断更新右边的区间即可。
代码
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