Interval List Intersections

Last updated

Last updated
Input:
A =
[[0,2],[5,10],[13,23],[24,25]]
, B =
[[1,5],[8,12],[15,24],[25,26]]
Output:
[[1,2],[5,5],[8,10],[15,23],[24,24],[25,25]]
Reminder:
The inputs and the desired output are lists of Interval objects, and not arrays or lists.0 <= A.length < 1000
0 <= B.length < 1000
0 <= A[i].start, A[i].end, B[i].start, B[i].end < 10^9class Solution:
def intervalIntersection(self, A: List[List[int]], B: List[List[int]]) -> List[List[int]]:
res = []
a = b = 0
while a<len(A) and b <len(B):
tail = min(A[a][1], B[b][1])
head = max(A[a][0], B[b][0])
if head <= tail:
res.append([head,tail]) #有交集就加入
#哪个end小就放弃,一样的话一起放弃
if A[a][1] == tail:
a += 1
if B[b][1] == tail:
b += 1
return res