Given a set of intervals, find the interval which has the maximum number of intersections

后端 未结 2 1658
忘了有多久
忘了有多久 2020-12-05 11:34

Given a set of intervals, find the interval which has the maximum number of intersections (not the length of a particular intersection). So if input (1,6) (2,3) (4,11), (1,6

2条回答
  •  天涯浪人
    2020-12-05 12:08

    Note: David Eisenstat's algorithm has better performance than this one.

    A simple plane-sweep algorithm will do this in O(nlogn + m*n), where m is the maximum number of intersections with any single interval.

    Sort the interval endpoints. Keep track of the active segments. When reaching a start point, increment the intersection counts of all active intervals, and set the new interval's intersection count to the number of active intervals (excluding itself). When reaching an end point, remove the interval from the active intervals.

提交回复
热议问题