986. 区间列表的交集
题目
给定两个由一些 闭区间 组成的列表,firstList 和 secondList ,其中 firstList[i] = [starti, endi] 而 secondList[j] = [startj, endj] 。每个区间列表都是成对 不相交 的,并且 已经排序 。
返回这 两个区间列表的交集 。
形式上,闭区间 [a, b](其中 a <= b)表示实数 x 的集合,而 a <= x <= b 。
两个闭区间的 交集 是一组实数,要么为空集,要么为闭区间。例如,[1, 3] 和 [2, 4] 的交集为 [2, 3] 。
来源:力扣(LeetCode)链接
代码
class Solution:
def intervalIntersection(self, firstList: List[List[int]], secondList: List[List[int]]) -> List[List[int]]:
ans, n1, n2 = [], len(firstList), len(secondList)
i = j = 0
while i < n1 and j < n2:
left = max(firstList[i][0], secondList[j][0])
right = min(firstList[i][1], secondList[j][1])
if left <= right:
ans.append([left, right])
if firstList[i][1] > secondList[j][1]:
j += 1
else:
i += 1
return ans
复杂度分析
- 时间复杂度: O(n)
- 空间复杂度: O(1)