Geometry Made Simple
来源:互联网 发布:网络教育托管 编辑:程序博客网 时间:2024/05/29 11:47
Geometry Made Simple
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
Mathematics can be so easy when you have a computer. Consider the following example. You probably know that in a right-angled triangle, the length of the three sides a, b, c (where c is the longest side, called the hypotenuse) satisfy the relation a*a+b*b=c*c. This is called Pythagora's Law.
Here we consider the problem of computing the length of the third side, if two are given.
Here we consider the problem of computing the length of the third side, if two are given.
输入
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.
A description having a=b=c=0 terminates the input.
输出
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.
Print a blank line after each test case.
示例输入
3 4 -1-1 2 75 -1 30 0 0
示例输出
Triangle #1c = 5.000Triangle #2a = 6.708Triangle #3Impossible.
提示
来源
面向对数据结构和算法不太懂的同学
示例程序
#include <stdio.h> #include<math.h> int main() { double a,b,c,d; int k=0; while(scanf("%lf%lf%lf",&a,&b,&c),(a||b||c)) { k++; if(a==-1) { d=sqrt(c*c-b*b); if(d>c-b&&d<c+b) printf("Triangle #%d\na = %.3lf\n\n",k,d); else printf("Triangle #%d\nImpossible.\n\n",k); } if(b==-1) { d=sqrt(c*c-a*a); if(d>c-a&&d<c+a) printf("Triangle #%d\nb = %.3lf\n\n",k,d); else printf("Triangle #%d\nImpossible.\n\n",k); } if(c==-1) { d=sqrt(a*a+b*b); if(d>fabs(b-a)&&d<a+b) printf("Triangle #%d\nc = %.3lf\n\n",k,d); else printf("Triangle #%d\nImpossible.\n\n",k); } } return 0; }
0 0
- Geometry Made Simple
- zoj1241-Geometry Made Simple
- Geometry Made Simple
- Geometry Made Simple
- zoj_1241 Geometry Made Simple
- 1241 Geometry Made Simple
- Geometry Made Simple
- zoj1241 Geometry Made Simple
- Geometry Made Simple
- Geometry Made Simple
- fjnu 1670 Geometry Made Simple
- zoj 1241 Geometry Made Simple
- ZOJ 1241 Geometry Made Simple
- zoj 1241.Geometry Made Simple
- zoj 1241 Geometry Made Simple
- zoj 1241 Geometry Made Simple
- ZOJ 1241: Geometry Made Simple
- ZOJ 1241 Geometry Made Simple
- mac os 10.11.1 安装cocoapods 出错
- 内存泄露概述
- no macthing function to call for QSqlQuery::bindValue()
- 网站的安全架构
- U3D 平行光阴影细节 Directional Shadow Details
- Geometry Made Simple
- 说说你对Android系统的理解
- ncurses的初始化
- 关于Fragment 不响应onActivityResult的情况分析
- MFG总结(8) -- ShellExecute与ShellExecuteEx的用法
- Doubles
- TIOBE 2015年11月编程语言排行榜 2009年7月以来Java再次超20%
- Metasploit概述
- Xcode升级后, 插件管理Alcatraz 失效解决方法