Pro.ID10171 TitleClosed Fences Title链接http://10.20.2.8/oj/exercise/problem?problem_id=10171 AC4 Submit16 Ratio25.00% 时间&空间限制描述A closed fence in the plane is a set of non-crossing, connected line segments with N corners (3 < N < 200). The corners or vertices are each distinct and are listed in counter-clockwise order in an array { xi, yi}, i in ( 1 .. N ). Every pair of adjacent vertices defines a side of the fence. Thus { xi , yi , xi+1 , yi+1} is a side of the fence for all i in ( 1 .. N ). For our purposes, N+1 = 1, so that the first and last vertices making the fence closed. Here is a typical closed fence and a point x, y: * x3,y3 Write a program which will do the following:
A fence side can be seen if there exists a ray that connects ( x , y ) and any point on the side, and the ray does not intersect any other side of the fence. A side that is parallel to the line of sight is not considered visible. In the figure, above the segments (x3, y3)-(x4, y4); (x5, y5)-(x6, y6); and (x6, y6)-(x1, y1) are visible or partially visible from x, y. 输入Line 1: N, the number of corners in the fence Line 2: Two space-separated integers, x and y, that are the location of the observer. Both integers will fit into 16 bits. Line 3-N+2: A pair of space-separated integers denoting the X, Y location of the corner. The pairs are given in counterclockwise order. Both integers are no larger than 1000 in magnitude. 输出Description A closed fence in the plane is a set of non-crossing, connected line segments with N corners (3 < N < 200). The corners or vertices are each distinct and are listed in counter-clockwise order in an array { xi, yi}, i in ( 1 .. N ). Every pair of adjacent vertices defines a side of the fence. Thus { xi , yi , xi+1 , yi+1} is a side of the fence for all i in ( 1 .. N ). For our purposes, N+1 = 1, so that the first and last vertices making the fence closed. Here is a typical closed fence and a point x, y: * x3,y3 Write a program which will do the following:
A fence side can be seen if there exists a ray that connects ( x , y ) and any point on the side, and the ray does not intersect any other side of the fence. A side that is parallel to the line of sight is not considered visible. In the figure, above the segments (x3, y3)-(x4, y4); (x5, y5)-(x6, y6); and (x6, y6)-(x1, y1) are visible or partially visible from x, y. Input Line 1: N, the number of corners in the fence Line 2: Two space-separated integers, x and y, that are the location of the observer. Both integers will fit into 16 bits. Line 3-N+2: A pair of space-separated integers denoting the X, Y location of the corner. The pairs are given in counterclockwise order. Both integers are no larger than 1000 in magnitude. Output If the sequence is not a valid fence, the output is a single line containing the word "NOFENCE". Otherwise, the output is a listing of visible fence segments, one per line, shown as four space-separated integers that represent the two corners. Express the points in the segment by showing first the point that is earlier in the input, then the point that is later. Sort the segments for output by examining the last point and showing first those points that are earlier in the input. Use the same rule on the first of the two points in case of ties. Sample Input 13 Sample Output 7 Source 样例输入13 样例输出7 作者 |