sdut 相似三角形
阿新 • • 發佈:2019-01-24
#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;
}
#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;
}