Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

binary search

data structures

geometry

*3500

No tag edit access

The problem statement has recently been changed. View the changes.

×
G. Cut the pie

time limit per test

3 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputArkady reached the *n*-th level in Township game, so Masha decided to bake a pie for him! Of course, the pie has a shape of convex *n*-gon, i.e. a polygon with *n* vertices.

Arkady decided to cut the pie in two equal in area parts by cutting it by a straight line, so that he can eat one of them and give the other to Masha. There is a difficulty because Arkady has already put a knife at some point of the pie, so he now has to cut the pie by a straight line passing trough this point.

Help Arkady: find a line that passes through the point Arkady has put a knife into and cuts the pie into two parts of equal area, or determine that it's impossible. Your program has to quickly answer many queries with the same pie, but different points in which Arkady puts a knife.

Input

The first line contains two integers *n* and *q* (3 ≤ *n* ≤ 10^{4}, 1 ≤ *q* ≤ 10^{5}) — the number of vertices in the pie and the number of queries.

*n* line follow describing the polygon vertices in clockwise order. The *i*-th of these line contains two integers *x*_{i} and *y*_{i} ( - 10^{6} ≤ *x*_{i}, *y*_{i} ≤ 10^{6}) — the coordinates of the *i*-th vertex. It is guaranteed that the polygon is strictly convex, in particular, no three vertices line on the same line.

An empty line follows.

*q* lines follow describing the query points. The *i*-th of these lines contain two integers *x*_{i} and *y*_{i} ( - 10^{6} ≤ *x*_{i}, *y*_{i} ≤ 10^{6}) — the coordinates of the point in which Arkady puts the knife in the *i*-th query. In is guaranteed that in each query the given point is strictly inside the polygon, in particular, is not on its edges.

Output

For each query print single integer — the polar angle of the line that is the answer for the corresponding query, in radians. The angle should be in the segment [0;π], the angles are measured from the direction of *OX* axis in counter-clockwise order. For example, the polar angle of the *OY* axis is . If there is no answer in that query, print -1.

If there are several answers, print any of them. Your answer is considered correct if the difference between the areas of the parts divided by the total area of the polygon doesn't exceed 10^{ - 4} by absolute value. In other words, if *a* and *b* are the areas of the parts after the cut, then your answer is correct if and only of .

Examples

Input

3 1

0 0

0 3

3 0

1 1

Output

2.67794504460098710000

Input

5 3

6 5

6 3

5 0

0 0

0 5

5 4

3 3

5 2

Output

0.60228734612690049000

1.27933953226473580000

2.85805511179015910000

Codeforces (c) Copyright 2010-2024 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Feb/28/2024 19:38:13 (l3).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|