codeforces 782B The Meeting Place Cannot Be Changed+hdu 4355+hdu 2438 (三分)
The main road in Bytecity is a straight line from south to north. Conveniently, there are coordinates measured in meters from the southernmost building in north direction.
At some points on the road there are n friends, and i-th of them is standing at the point xi meters and can move with any speed no greater than vi meters per second in any of the two directions along the road: south or north.
You are to compute the minimum time needed to gather all the n friends at some point on the road. Note that the point they meet at doesn't need to have integer coordinate.
The first line contains single integer n (2 ≤ n ≤ 60 000) — the number of friends.
The second line contains n integers x1, x2, ..., xn (1 ≤ xi ≤ 109) — the current coordinates of the friends, in meters.
The third line contains n integers v1, v2, ..., vn (1 ≤ vi ≤ 109) — the maximum speeds of the friends, in meters per second.
Print the minimum time (in seconds) needed for all the n friends to meet at some point on the road.
Your answer will be considered correct, if its absolute or relative error isn't greater than 10 - 6. Formally, let your answer be a, while jury's answer be b. Your answer will be considered correct if holds.
3
7 1 3
1 2 1
2.000000000000
4
5 10 3 2
2 3 2 4
1.400000000000
In the first sample, all friends can gather at the point 5 within 2 seconds. In order to achieve this, the first friend should go south all the time at his maximum speed, while the second and the third friends should go north at their maximum speeds.
题意:x轴上有n个人 坐标为xi 最大行驶速度为vi 让这n个人走到相同一点的最短时间上多少
三分坐标 每次看到达这个坐标的最大时间 相互比较
1 #include<iostream> 2 #include<cstdio> 3 #include<cmath> 4 #include<map> 5 #include<cstdlib> 6 #include<vector> 7 #include<set> 8 #include<queue> 9 #include<cstring> 10 #include<string.h> 11 #include<algorithm> 12 #define INF 0x3f3f3f3f 13 typedef long long ll; 14 typedef unsigned long long LL; 15 using namespace std; 16 const double eps=0.0000001; 17 const int N=60000+100; 18 double a[N],b[N]; 19 int n; 20 double fun(double x){ 21 double ans=0; 22 for(int i=0;i<n;i++)ans=max(ans,fabs(x-a[i])/b[i]); 23 return ans; 24 } 25 int main(){ 26 while(scanf("%d",&n)!=EOF){ 27 double maxx=-1.0*INF; 28 double minn=1.0*INF; 29 for(int i=0;i<n;i++){ 30 scanf("%lf",&a[i]); 31 maxx=max(maxx,a[i]); 32 minn=min(minn,a[i]); 33 } 34 for(int i=0;i<n;i++)scanf("%lf",&b[i]); 35 double high=maxx; 36 double low=minn; 37 while(low+eps<high){ 38 double mid=(high+low)/2.0; 39 double midd=(mid+high)/2.0; 40 if(fun(mid)<fun(midd))high=midd; 41 else 42 low=mid; 43 } 44 printf("%.12f\n",fun(low)); 45 } 46 }
hdu 4355
Party All the Time
Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 5384 Accepted Submission(s): 1679
Now give you every spirit's weight and location,find the best place to celebrate the harvest which make the sum of unhappyness of every spirit the least.
#include<iostream> #include<cstdio> #include<cmath> #include<map> #include<cstdlib> #include<vector> #include<set> #include<queue> #include<cstring> #include<string.h> #include<algorithm> #define INF 0x3f3f3f3f typedef long long ll; typedef unsigned long long LL; using namespace std; const double eps=0.00000001; const int N=100000+100; int n; struct node{ double x; double w; }a[N]; double fun(double x){ double ans=0.0; for(int i=0;i<n;i++){ double t=fabs(a[i].x-x); ans=ans+t*t*t*a[i].w; } return ans; } int main(){ //cout<<eps<<endl; int t; scanf("%d",&t); for(int k=1;k<=t;k++){ scanf("%d",&n); double minn=1.0*INF; double maxx=-1.0*INF; for(int i=0;i<n;i++){ scanf("%lf%lf",&a[i].x,&a[i].w); maxx=max(maxx,a[i].x); minn=min(minn,a[i].x); } double low=minn; double high=maxx; double ans=low; while(low+eps<high){ double mid=(low+high)/2.0; double midd=(mid+high)/2.0; // cout<<fun(mid)<<" "<<fun(midd)<<endl; if(fun(mid)<fun(midd)){ high=midd; } else{ low=mid; ans=low; } } printf("Case #%d: %.0f\n",k,fun(ans)); } }
hdu 2438
Turn the corner
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 3181 Accepted Submission(s): 1289
One day he comes to a vertical corner. The street he is currently in has a width x, the street he wants to turn to has a width y. The car has a length l and a width d.
Can Mr. West go across the corner?
Proceed to the end of file.
1 #include<iostream> 2 #include<cstdio> 3 #include<cmath> 4 #include<map> 5 #include<cstdlib> 6 #include<vector> 7 #include<set> 8 #include<queue> 9 #include<cstring> 10 #include<string.h> 11 #include<algorithm> 12 #define INF 0x3f3f3f3f 13 typedef long long ll; 14 typedef unsigned long long LL; 15 using namespace std; 16 const double PI=acos(-1.0); 17 const double eps=0.00000001; 18 double x,y,l,w; 19 double fun(double a){ 20 double ans=l*cos(a)-(x-w/cos(a))/tan(a); 21 return ans; 22 } 23 int main(){ 24 while(scanf("%lf%lf%lf%lf",&x,&y,&l,&w)!=EOF){ 25 double low=0.0; 26 double high=PI/2.0; 27 if(x<w||y<w) 28 { 29 cout<<"no"<<endl; 30 continue; 31 } 32 while(low+eps<high){ 33 double mid=(low+high)/2.0; 34 double midd=(mid+high)/2.0; 35 if(fun(mid)<=fun(midd)){ 36 low=mid; 37 } 38 else 39 high=midd; 40 } 41 if(fun(low)<=y)cout<<"yes"<<endl; 42 else 43 cout<<"no"<<endl; 44 } 45 }