Given two Convex PolygonPAndQTo find the point (P,Q)(PBelongPAndQBelongQ) To maximize the distance between them.
Intuitively, these points cannot belong to the interior of their respective polygon. This is actually very similar to the diameter problem:
Two convex polygonPAndQThe maximum distance between two polygon is determined by the pair vertex between the polygon. Even so, this definition is different from that of the given convex polygon to the vertex pair. Essentially, the difference between a vertex and a convex polygon is that the tangent is directed and backward. Is an example:
The above conclusion implies that not only the vertex pair needs to be checked, but only the specific vertex pair is considered. In fact, they only detect parallel tangent established by an algorithm based on the rotating jamming mode.
Consider the following algorithm. The input of the algorithm is two convex polygon.PAndQ, They haveMAndNClockwise vertex.
1. ComputingPUpperYVertex with the smallest coordinate value (calledYminp) AndQUpperYThe vertex with the largest coordinate value (calledYmaxq).
2. PolygonYminpAndYmaxqConstruct two tangent linesLpAndSCSIPlace the corresponding polygon on their right side. In this caseLpAndSCSIHas different directions, andYminpAndYmaxqIt becomes a pair of vertex points between polygon.
3. Calculate the distance (Yminp,YmaxqAnd maintain it as the current maximum value.
4. Rotate parallel lines clockwise at the same time until one of them overlaps with the edges of the polygon.
5. A new vertex pair is generated. Calculate the new distance, which is compared with the current maximum value. If it is greater than the current maximum value, it is updated. If the two lines overlap with the edge at the same time, a total of three pair of vertex points (the combination of the previous vertex and the new vertex) need to be taken into account.
6. Repeat steps 4 and 5 until the new point is (Yminp,Ymaxq).
7. maximum output distance.
The rotating jamming mode ensures that all pair of signature points are taken into account. In addition, the entire algorithm has linear time complexity because (except initialization) the number of execution steps is the same as the number of vertices.
Similar algorithms can be used in the problem of minimum distance between convex polygon.