三角形面积

    xiaoxiao2021-03-26  19

    三角形面积

    时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 2 描述 给你三个点,表示一个三角形的三个顶点,现你的任务是求出该三角形的面积 输入 每行是一组测试数据,有6个整数x1,y1,x2,y2,x3,y3分别表示三个点的横纵坐标。(坐标值都在0到10000之间) 输入0 0 0 0 0 0表示输入结束 测试数据不超过10000组 输出 输出这三个点所代表的三角形的面积,结果精确到小数点后1位(即使是整数也要输出一位小数位) 样例输入 0 0 1 1 1 3 0 1 1 0 0 0 0 0 0 0 0 0 样例输出 1.0 0.5

    import java.text.DecimalFormat; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner=new Scanner(System.in); int x1=scanner.nextInt(); int y1=scanner.nextInt(); int x2=scanner.nextInt(); int y2=scanner.nextInt(); int x3=scanner.nextInt(); int y3=scanner.nextInt(); while(x1!=0 || x2!=0 || x3!=0 || y1!=0 || y2!=0 || y3!=0) { double a=Math.sqrt(Math.pow(x1-x2,2)+Math.pow(y1-y2,2)); double b=Math.sqrt(Math.pow(x1-x3,2)+Math.pow(y1-y3,2)); double c=Math.sqrt(Math.pow(x2-x3,2)+Math.pow(y2-y3,2)); double s=0; if(a+b>c && a+c>b && b+c>a) { double p=(a+b+c)/2.0; s=Math.sqrt(p*(p-a)*(p-b)*(p-c)); } DecimalFormat decimalFormat=new DecimalFormat("#0.0"); System.out.println(decimalFormat.format(s)); x1=scanner.nextInt(); y1=scanner.nextInt(); x2=scanner.nextInt(); y2=scanner.nextInt(); x3=scanner.nextInt(); y3=scanner.nextInt(); } } }

    转载请注明原文地址: https://ju.6miu.com/read-660670.html

    最新回复(0)