相似三角形
Time Limit: 1000 ms Memory Limit: 65536 KiB
Problem Description
给出两个三角形的三条边,判断是否相似。
Input
多组数据,给出6正个整数,a1,b1,c1,a2,b2,c2,分别代表两个三角形。(边长小于100且无序)
Output
如果相似输出YES,如果不相似输出NO,如果三边组不成三角形也输出NO。
Sample Input
1 2 3 2 4 6
3 4 5 6 8 10
3 4 5 7 8 10
Sample Output
NO
YES
NO
Hint
Source
import java.util.Scanner;
public class Main {
public static void main(String args[]) {
Scanner input = new Scanner(System.in);
while(input.hasNextInt()) {
int a1,b1,c1,a2,c2,b2,n,flag;
a1 = input.nextInt();
b1 = input.nextInt();
c1 = input.nextInt();
a2 = input.nextInt();
b2 = input.nextInt();
c2 = input.nextInt();
//以下if语句用来排序,按三条边从小到大排序
if(a1 > b1) {
n = a1;
a1 = b1;
b1 = n;
}
if(a1 > c1) {
n = a1;
a1 = c1;
c1 = n;
}
if(b1 > c1) {
n = b1;
b1 = c1;
c1 = n;
}
if(a2> b2) {
n = a2;
a2 = b2;
b2 = n;
}
if(a2 > c2) {
n = a2;
a2 = c2;
c2 = n;
}
if(b2 > c2) {
n = b2;
b2 = c2;
c2 = n;
}
flag = 0;
//判断三条边能否组成三角形,任意两边之和大于第三边,任意两边之差小于第三边
if(a1+b1 <= c1) {
flag = 1;
}
else if(c1 - b1 >= a1) {
flag = 1;
}
if(flag==1) {
System.out.println("NO");
}
else {
if(a1 < a2) {
if((a2*1.0/a1 == b2*1.0/b1)&& (a2*1.0/a1 == c2*1.0/c1)) { //判断两三角形的三条边是否成比例,可能是小数
System.out.println("YES");
}
else System.out.println("NO");
}
else {
if((a1*1.0/a2 == b1*1.0/b2 )&& (a1*1.0/a2== c1*1.0/c2)) {
System.out.println("YES");
}
else System.out.println("NO");
}
}
}
input.close();
}
}