package leetcode
import (
"github.com/halfrost/LeetCode-Go/structures"
)
type Interval = structures.Interval
func intervalIntersection(A []Interval, B []Interval) []Interval {
res := []Interval{}
for i, j := 0, 0; i < len(A) && j < len(B); {
start := max(A[i].Start, B[j].Start)
end := min(A[i].End, B[j].End)
if start <= end {
res = append(res, Interval{Start: start, End: end})
}
if A[i].End <= B[j].End {
i++
} else {
j++
}
}
return res
}
func max(a int, b int) int {
if a > b {
return a
}
return b
}
func min(a int, b int) int {
if a > b {
return b
}
return a
}