zoukankan      html  css  js  c++  java
  • 【0709作业】判断三个数是否能组成三角形以及组成的三角形类型

    Sjx类

     1 package sjx;
     2 /**
     3  * 判断三个数是否能组成三角形以及组成的三角形类型
     4  * 2019-07-10
     5  * @author L
     6  *
     7  */
     8 public class Sjx {
     9     
    10         int a;
    11         int b;
    12         int c;
    13         boolean boo = false;
    14 
    15         public Sjx() {
    16         }
    17 
    18         public Sjx(int a, int b, int c) {
    19             if (a >= b && a >= c) {
    20                 boo = a < (b + c) ? true : false;
    21             } else if (b >= a && b >= c) {
    22                 boo = b < (a + c) ? true : false;
    23             } else if (c >= a && c >= b) {
    24                 boo = c < (a + b) ? true : false;
    25             }
    26         }
    27 
    28         public void showInfo(int a, int b, int c) {
    29             int sjx = 0;//判断三角形
    30             if (a >= b && a >= c) {
    31                 // 如果任意一条边的平方等于其他两边的平方之和 为直角三角形
    32                 // 大于 为 钝角三角形
    33                 // 否则 为锐角三角形
    34                 if ((a * a) == (b * b + c * c)) {
    35                     sjx = 1;
    36                 } else if ((a * a) > (b * b + c * c)) {
    37                     sjx = 2;
    38                 } else {
    39                     sjx = 3;
    40                 }
    41             } else if (b >= a && b >= c) {
    42                 if ((b * b) == (a * a + c * c)) {
    43                     sjx = 1;
    44                 } else if ((b * b) > (a * a + c * c)) {
    45                     sjx = 2;
    46                 } else {
    47                     sjx = 3;
    48                 }
    49             } else if (c >= a && c >= b) {
    50                 if ((c * c) == (b * b + a * a)) {
    51                     sjx = 1;
    52                 } else if ((c * c) > (b * b + a * a)) {
    53                     sjx = 2;
    54                 } else {
    55                     sjx = 3;
    56                 }
    57             }
    58             switch (sjx) {
    59             case 1:
    60                 System.out.println("这是一个直角三角形!");
    61                 break;
    62             case 2:
    63                 System.out.println("这是一个钝角三角形!");
    64                 break;
    65             case 3:
    66                 System.out.println("这是个锐角三角形!");
    67             }
    68         }
    69     }

    测试类

     1 package sjx;
     2 
     3 import java.util.Scanner;
     4 
     5 public class Main {
     6     static Scanner sc=new Scanner(System.in);
     7     public static void main(String[] args) {
     8         String xz = "";
     9         do {
    10             // 输入三条边长
    11             System.out.println("请输入第1条边长:");
    12             int a = sc.nextInt();
    13             System.out.println("请输入第2条边长:");
    14             int b = sc.nextInt();
    15             System.out.println("请输入第3条边长:");
    16             int c = sc.nextInt();
    17             // 判断是否构成三角形 满足条件:任意两边之和大于第三边
    18             Sjx shape = new Sjx(a, b, c);
    19             if (shape.boo) {
    20                 shape.showInfo(a, b, c);
    21             } else {
    22                 System.out.println("这不能构成三角形!");
    23             }
    24             System.out.println("是否继续(输入y继续否则退出):");
    25             xz = sc.next();
    26 
    27         } while ("y".equals(xz));
    28         System.out.println("程序结束!");
    29     }
    30 }
  • 相关阅读:
    如何用redis/memcache做Mysql缓存层?
    孤儿进程和僵尸进程总结
    二叉树的遍历(非递归)
    Linux进程分配内存的两种方式--brk() 和mmap()
    Hbase
    cgroup 分析之CPU和内存部分
    十道海量数据处理面试题与十个方法大总结
    快速定位性能瓶颈,检查出所有资源(CPU、内存、磁盘IO等)的利用率(utilization)、饱和度(saturation)和错误(error)度量,即USE方法
    红黑树
    tcp 两个重要窗口:滑动窗口 和 拥塞窗口
  • 原文地址:https://www.cnblogs.com/yanglanlan/p/11167197.html
Copyright © 2011-2022 走看看