Given two lists of closed intervals, each list of intervals is pairwise disjoint and in sorted order.

This problem can be divided into two steps, finding intervals from two lists and looping through lists

Let’s see what kind of overlaps can occur

From the image the condition for overlap is

In order to get start and end of the overlapping range

Now we need to figure out how to loop through the lists A and B

You can use two pointers technique. See below image to understand better

Here’s the code

```
/**
* @param {number[][]} A
* @param {number[][]} B
* @return {number[][]}
*/
var intervalIntersection = function(A, B) {
let res = new Array()
let i = 0, j = 0
while(i < A.length && j < B.length) {
let lo = Math.max(A[i][0], B[j][0])
let hi = Math.min(A[i][1], B[j][1])
if(lo <= hi) {
res.push([lo, hi])
}
if(A[i][1] < B[j][1]) {
i++ // A length is over go to next one
} else {
j++
}
}
return res
};
```