1. 程式人生 > >JAVA判斷三角形的型別

JAVA判斷三角形的型別

今天看到一段判斷三角形型別的java程式碼,然後自己寫了一個小程式

	 public static void main(String[] args) {
		 double chang[] = new double[3];
		 Scanner sc = new Scanner(System.in);
		 boolean flag = true;
		 int n = 0;
		 System.out.println("--------開始--------");
		 while(flag){
			 if(n > 0){
				 System.out.println("是否繼續:F-停止,T-繼續");
				 String str = sc.next();
				 if("F".equals(str)){
					 System.out.println("--------結束--------");
					 break;
				 }else  if(!"T".equals(str)){
					 System.out.println("操作不合法,請重新輸入:");
					 continue;
				 }
			 }
			 System.out.println("請輸入三角形三條邊:");
			 for (int i = 0; i < chang.length; i++) {
				chang[i] = sc.nextDouble();
			 }
			 n++;
			 Arrays.sort(chang); //從小到大排序
			 if(chang[0] + chang[1] > chang[2]){  //兩邊之和大於第三邊
				 //System.out.println(Math.sqrt(2)); //1.4142135623730951
				 //System.out.println(Math.pow(1.4142135623730951,2)); //2.0000000000000004  
				 //由於不能輸入根號2,就用1.4142135623730951代替,模擬一下直角三角形,平方之後是2.0000000000000004
				 if((int)(chang[2]*chang[2]) == (int)(chang[1]*chang[1]) + (int)(chang[0]*chang[0])){
					 if(chang[2] == chang[1] || chang[2] == chang[0] || chang[1] == chang[0]){
						 System.out.println("該三角形是等腰直角三角形");  
						 continue;
					 }else{
						 System.out.println("該三角形是直角三角形");
						 continue;
					 }				 
				 }else if(chang[0] == chang[1] && chang[1]== chang[2]){
					 System.out.println("該三角形是等邊三角形");
					 continue;
				 }else if(chang[2] == chang[1] || chang[2] == chang[0] || chang[1] == chang[0]){
					 System.out.println("該三角形是等腰三角形");
					 continue;
				 }else{
					 System.out.println("該三角形是普通三角形");
					 continue;
				 }
			 }else{
				 System.out.println("不是三角形");
				 continue;
			 }
		 }
		 
	}
執行結果:

--------開始--------
請輸入三角形三條邊:
1 4 7
不是三角形
是否繼續:F-停止,T-繼續
2
操作不合法,請重新輸入:
是否繼續:F-停止,T-繼續
T
請輸入三角形三條邊:
3 4 5
該三角形是直角三角形
是否繼續:F-停止,T-繼續
T
請輸入三角形三條邊:
1.4142135623730951 1.4142135623730951 2
該三角形是等腰直角三角形
是否繼續:F-停止,T-繼續
T
請輸入三角形三條邊:
6 6 6
該三角形是等邊三角形
是否繼續:F-停止,T-繼續
T
請輸入三角形三條邊:
4 6 6
該三角形是等腰三角形
是否繼續:F-停止,T-繼續
F
--------結束--------