1. 程式人生 > >sdut 相似三角形

sdut 相似三角形

#include <iostream>
#include<algorithm>
//相似三角形的條件:
//1、任意兩邊之和大於第三邊或者任意兩邊之差小於第三邊
//2,三條邊對應的比例相等
using namespace std;


int main()
{
    float a[3];
    float b[3];
    bool result;
    while(cin>>a[0]>>a[1]>>a[2]>>b[0]>>b[1]>>b[2])  //多組輸入
    {


        result=(a[0]+a[1]>a[2]&&a[0]+a[2]>a[1]&&a[1]+a[2]>a[0]&&b[0]+b[1]>b[2]&&b[0]+b[2]>b[1]&&b[1]+b[2]>b[0]);  //判斷是否為三角形
        if(result)
        {
            sort(a,a+3);//講陣列從小到大排序
            sort(b,b+3);
            if(a[0]>b[0])
            {
                if(a[0] / b[0] == a[1] / b[1] && a[0] / b[0] == a[2] / b[2] && a[1] / b[1] == a[2] / b[2])  //三條邊對應的比例是否相等
                    cout<<"YES"<<endl;
                else
                    cout<<"NO"<<endl;
            }
            else
            {
                if(b[0] / a[0] == b[1] / a[1] && b[0] / a[0] == b[2] / a[2] && b[1] / a[1] == b[2] / a[2])
                 cout<<"YES"<<endl;
                else
                cout<<"NO"<<endl;


            }
        }
        else
            cout<<"NO"<<endl;


    }




    return 0;
}