Time Limit: 0.5 second(s) | Memory Limit: 32 MB |
See the picture below.
You are given AB, AC and BC. DE is parallel to BC. You are also given the area ratio between ADE and BDEC. You have to find the value of AD.
Input
Input starts with an integer T (≤ 25), denoting the number of test cases.
Each case begins with four real numbers denoting AB, AC, BC and the ratio of ADE and BDEC (ADE / BDEC). You can safely assume that the given triangle is a valid triangle with positive area.
Output
For each case of input you have to print the case number and AD. Errors less than 10-6 will be ignored.
Sample Input | Output for Sample Input |
4 100 100 100 2 10 12 14 1 7 8 9 10 8.134 9.098 7.123 5.10 | Case 1: 81.6496580 Case 2: 7.07106781 Case 3: 6.6742381247 Case 4: 7.437454786 |
题意:如图ABC和ADE是相似三角形,给出AB AC BC边和SADE/SBDEC求AD边长。
思路:设两个三角形的高分别为h H,设比例k=h/H = ad/ab = de/bc = ae/ac
Sade/Sbdec=1/(Sabc/Sade-1) =rs
Sabc/Sade=(1+rs)/rs = k^2 -->k
ad=ab*k
代码:
#include<cstdio>
#include<cmath>
#define LL long long
int main()
{
int t,kcase=1;
double ab,ac,bc,rs,k,ad;
scanf("%d",&t);
while(t--)
{
scanf("%lf%lf%lf%lf",&ab,&ac,&bc,&rs);
k=sqrt(rs/(1+rs));
ad=ab*k;
printf("Case %d: %.7lf\n",kcase++,ad);
}
return 0;
}