Codeforces Round #113 (Div. 2)
题目链接:Polygons
You’ve got another geometrical task. You are given two non-degenerate polygons $A$ and $B$ as vertex coordinates. Polygon $A$ is strictly convex. Polygon $B$ is an arbitrary polygon without any self-intersections and self-touches. The vertices of both polygons are given in the clockwise order. For each polygon no three consecutively following vertices are located on the same straight line.
Your task is to check whether polygon $B$ is positioned strictly inside polygon $A$. It means that any point of polygon $B$ should be strictly inside polygon $A$. “Strictly” means that the vertex of polygon $B$ cannot lie on the side of the polygon $A$.
Input
The first line contains the only integer $n (3 \le n \le 10^5)$ — the number of vertices of polygon $A$. Then $n$ lines contain pairs of integers $x_i, y_i (|x_i|, |y_i| \le 10^9)$ — coordinates of the i-th vertex of polygon $A$. The vertices are given in the clockwise order.
The next line contains a single integer $m (3 \le m \le 2·10^4)$ — the number of vertices of polygon $B$. Then following $m$ lines contain pairs of integers $x_j, y_j (|x_j|, |y_j| \le 10^9)$ — the coordinates of the $j$-th vertex of polygon $B$. The vertices are given in the clockwise order.
The coordinates of the polygon’s vertices are separated by a single space. It is guaranteed that polygons $A$ and $B$ are non-degenerate, that polygon $A$ is strictly convex, that polygon $B$ has no self-intersections and self-touches and also for each polygon no three consecutively following vertices are located on the same straight line.
Output
Print on the only line the answer to the problem — if polygon $B$ is strictly inside polygon $A$, print “YES”, otherwise print “NO” (without the quotes).
Examples
input
6 -2 1 0 3 3 3 4 1 3 -2 2 -2 4 0 1 2 2 3 1 1 0
output
YES
input
5 1 2 4 2 3 -3 -2 -2 -2 1 4 0 1 1 2 4 1 2 -1
output
NO
input
5 -1 2 2 3 4 1 3 -2 0 -3 5 1 0 1 1 3 1 5 -1 2 -1
output
NO
Solution
题意
给定两个凸包 $A$ 和 $B$。判断凸包 $B$ 是否严格在凸包 $A$ 内。
题解
对凸包 $A$ 和 $B$ 的所有点构造凸包,判断该凸包是否等于凸包 $A$。若相等,则凸包 $B$ 严格在凸包 $A$ 内。
Code
1 |
|