# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
3447 | pichulia | Jogging (kriii1_J) | C++98 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>
using namespace::std;
#define M 100000005
double M_PI;
struct P{
double x, y;
double radis;
}a[100005];
int n, m;
double b[100005];
bool compare(P p, P q)
{
return p.radis > q.radis;
}
void input()
{
M_PI = acos(0.0)*2;
int i, j;
scanf("%d %d",&n,&m);
for(i=0; i<n; i++)
{
scanf("%lf %lf",&a[i].x,&a[i].y);
a[i].radis = atan2(a[i].y, a[i].x + M);
}
for(i=0; i<m; i++)
scanf("%lf",&b[i]);
sort(a,a+n,compare);
}
void process()
{
int i, j=0;
double k;
for(i=0; i<m; i++)
{
k=0;
for(; j<n; j++)
{
k = atan2(a[j].y,a[j].x - b[i]);
if(k<M_PI/2)
break;
}
printf("%.7lf\n",k);
}
}
void output()
{
}
int main()
{
input();
process();
output();
return 0;
}