zoukankan      html  css  js  c++  java
  • ZOJ1241--Geometry Made Simple

    Geometry Made Simple

    Time Limit: 2 Seconds      Memory Limit: 65536 KB

    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.

     

    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.


    Source: Southwestern Europe 1997, Practice

     1 #include <stdio.h>
     2 #include <math.h>
     3 int main()
     4 {
     5     char s ;
     6     int a, b, c, total = 1 ;
     7     while(~scanf("%d %d %d", &a, &b, &c))
     8     {
     9         if(!a && !b && !c)
    10         break ;
    11         printf("Triangle #%d
    ", total) ;
    12         if(a == -1 && b < c)
    13         printf("a = %.3lf
    
    ", sqrt(c*c - b*b)) ;
    14         else if(b == -1 && a < c) 
    15         printf("b = %.3lf
    
    ", sqrt(c*c - a*a)) ;
    16         else if(c == -1)
    17         printf("c = %.3lf
    
    ", sqrt(a*a + b*b)) ;
    18         else
    19         printf("Impossible.
    
    ") ;
    20         total++ ; 
    21     } 
    22     return 0 ;
    23     
    24 }
  • 相关阅读:
    可变参数模板的递归解析
    在Ubuntu上安装多个版本的g++ 并进行默认版本切换
    不错的威盾PHP加密专家解密算法
    文章相关性分析详细介绍
    c#连接mysql中文乱码解决方案(MySql.Data.dll)
    firefox用12306Helper 0.2结合ie tab+自动订火车票和完成支付全攻略
    Nutch命令大全
    Jtable利用SetModel进行数据绑定
    在php中使用CKEDITOR在线编辑器
    Nutch1.2搜索引擎使用详解
  • 原文地址:https://www.cnblogs.com/soTired/p/4663659.html
Copyright © 2011-2022 走看看