三角形判断

  • Description

给定三条边的长度,判断能否组成三角形,如果可以,判断三角形的形状。

  • Input

一组数据,每行三个实数,在(0,10]之间,精确到小数点后第四位。最后以0 0 0表示结束。

  • Output

根据每行的数据判断,如果不能组成三角形,则输出“Not a triangle”;如果是“等腰三角形”,则输出“Isosceles triangle”;如果是“直角三角形”,则输出“Right triangle”;如果是“等腰直角三角形”,则输出“Isosceles right triangle”;如果是“等边三角形”,则输出“Equilateral triangle”;否则,输出“General triangle”。最后输出一行“End”。

  • Sample Input

1.4142 1.4142 2
1.0000 4.0000 5.0000
0 0 0

  • Sample Output

Isosceles right triangle
Not a triangle
End

#include
using namespace std;
#define eps 1e-3
int main()
{
    //    freopen("in.txt","r",stdin);
    while(1)
    {
        double a,b,c;
        cin>>a>>b>>c;
        if(a"End"<;
            break;
        }
        double e;
        if(aa;
            a=b;
            b=e;
        }
        if(aa;
            a=c;
            c=e;
        }
        if(b;
            b=c;
            c=e;
        }
        if(b+c>a)
        {
            if(b-cif(a-b"Equilateral triangle"<;
                else if(b*b+c*c-a*aa*a-b*b-c*c"Isosceles right triangle"<;
                else
                    cout<<"Isosceles triangle"<;
            }
            else if(a-bif(b-c"Equilateral triangle"<;
                else
                    cout<<"Isosceles triangle"<;
            }
            else if(b*b+c*c-a*aa*a-b*b-c*c"Right triangle"<;
            else
                cout<<"General triangle"<;
        }
        else
            cout<<"Not a triangle"<;
    }
    return 0;
}

你可能感兴趣的:(南邮acm)