Here we consider the problem of computing the length of the third side, if two are given.
Input
The input contains the descriptions of several triangles. Each description consists of a line containing three integers a, b and c, giving the lengths of the respective sides of a right-angled triangle. Exactly one of the three numbers is equal to -1 (the 'unknown' side), the others are positive (the 'given' sides).
A description having a=b=c=0 terminates the input.
Output
For each triangle description in the input, first output the number of the triangle, as shown in the sample output. Then print "Impossible." if there is no right-angled triangle, that has the 'given' side lengths. Otherwise output the length of the 'unknown' side in the format "s = l", where s is the name of the unknown side (a, b or c), and l is its length. l must be printed exact to three digits to the right of the decimal point.
Print a blank line after each test case.
Sample Input
3 4 -1
-1 2 7
5 -1 3
0 0 0
Sample Output
Triangle #1
c = 5.000
Triangle #2
a = 6.708
Triangle #3
Impossible.
#include<stdio.h> #include<math.h> int main (void) { int a,b,c; int d=1; while(~scanf("%d%d%d",&a,&b,&c),a||b||c) { double aa,bb,cc; if(a==-1) { aa=c*c-b*b;//int 与double 混用情况,不正确但也能过,最好不要使用这种方法 printf("Triangle #%d\n",d); d++; if(aa<=0||b<=0||c<=0)//判断条件 { printf("Impossible.\n\n"); } else printf("a = %.3lf\n\n",sqrt(aa)); continue; } if(b==-1) { b=c*c-a*a;//正确的方法 printf("Triangle #%d\n",d); d++; bb=sqrt(b); if(b<=0||a<=0||c<=0)//不要判断a和c也可AC(漏洞) { printf("Impossible.\n\n"); } else printf("b = %.3lf\n\n",bb); continue; } if(c==-1) { cc=a*a+b*b; printf("Triangle #%d\n",d); d++; printf("c = %.3lf\n\n",sqrt(cc)); continue; } } return 0; }