codeforces 935 C. Fifa and Fafa
2018-03-08 16:46
435 查看
Description
Fifa and Fafa are sharing a flat. Fifa loves video games and wants to download a new soccer game. Unfortunately, Fafa heavily uses the internet which consumes the quota. Fifa can access the internet through his Wi-Fi access point. This access point can be accessed within a range of r meters (this range can be chosen by Fifa) from its position. Fifa must put the access point inside the flat which has a circular shape of radius R. Fifa wants to minimize the area that is not covered by the access point inside the flat without letting Fafa or anyone outside the flat to get access to the internet.The world is represented as an infinite 2D plane. The flat is centered at (x1, y1) and has radius R and Fafa’s laptop is located at (x2, y2), not necessarily inside the flat. Find the position and the radius chosen by Fifa for his access point which minimizes the uncovered area.
Input
The single line of the input contains 5 space-separated integers R, x1, y1, x2, y2 (1 ≤ R ≤ 105, |x1|, |y1|, |x2|, |y2| ≤ 105).Output
Print three space-separated numbers xap, yap, r where (xap, yap absolutely or relatively, and also the radius you printed can be changed by no more than 10 − 6 (absolutely or relatively) in such a way that all points outside the flat and Fafa’s laptop position are outside circle of the access point range.Examples
Input |
---|
5 3 3 1 1 |
Output |
3.7677669529663684 3.7677669529663684 3.914213562373095 |
Input |
---|
10 5 5 5 15 |
Output |
5.0 5.0 10.0 |
思路:先以房间中心建立相对坐标系,再选取fafa所在的直径长的那部分作为WI-FI的直径。
如图,(x3, y3)利用相似三角形是容易计算的,x3=−x1Rx21+y21√,y3=−y1Rx21+y21√,所以x2=x1+x32,y2=y1+y32,半径为R+Ra2
#include<stdio.h> #include<math.h> int main(){ double R,aR,iR,xR,yR,xa,ya,xi,yi,xt,yt; scanf("%lf %lf %lf %lf %lf",&R,&xR,&yR,&xa,&ya); xa=xa-xR; ya=ya-yR; //相对坐标 aR=sqrt(xa*xa+ya*ya); //Fafa在外面的情况 if(aR-R>0.0000001){ printf("%.10f %.10f %.10f\n",xR,yR,R); return 0; } //Fafa在中心的情况 if(aR<0.0000001){ printf("%.10f %.10f %.10f\n",xR+0.5*R,yR,R*0.5); return 0; } xt=-1*xa*R/aR; yt=-1*ya*R/aR; xi=(xt+xa)/2; yi=(yt+ya)/2; iR=(R+aR)/2; printf("%.10f %.10f %.10f\n",xi+xR,yi+yR,iR); return 0; }
相关文章推荐
- Codeforces-935C:Fifa and Fafa
- cf 465C. Fifa and Fafa
- CodeForces 935C Fifa and Fafa 计算几何
- CF 935 C. Fifa and Fafa 几何(贪心,相似)
- Codeforces Round #465 (Div. 2) C. Fifa and Fafa
- Codeforces 935C Fifa and Fafa 题解 附平面几何基础:平面向量基本运算
- codeforces 935 A. Fafa and his Company
- Codeforces Round #465 (Div. 2) C. Fifa and Fafa
- Codeforces-935D: Fafa and Ancient Alphabet(DP)
- codeforces 935 B. Fafa and the Gates
- CodeForces 148D Bag of mice
- Educational Codeforces Round 5 :(codeforces 616)
- CodeForces 589D(思路)
- Codeforces 798A -Mike and palindrome
- Codeforces 894C - Marco and GCD Sequence 【GCD+思维】
- CodeForces 482B Interesting Array
- CodeForces 614B Gena's Code
- codeforces 706D D. Vasiliy's Multiset(trie树)
- Codeforces 149 E. Martian Strings
- codeforces 894 A题 QAQ -mystical_curve