矩形面积交

问题描述

  平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴。对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积。

输入格式

  输入仅包含两行,每行描述一个矩形。
  在每行中,给出矩形的一对相对顶点的坐标,每个点的坐标都用两个绝对值不超过10^7的实数表示。

输出格式

  输出仅包含一个实数,为交的面积,保留到小数后两位。

样例输入

1 1 3 3
2 2 4 4

样例输出

1.00

import java.util.Scanner;
import java.text.DecimalFormat;
public class test1{
	public static double min(double x,double y) {
		return x<y?x:y;
	}
	public static double max(double x,double y) {
		return x>y?x:y;
	}
	public static void main(String[]args) {
		Scanner s=new Scanner(System.in);
		double x1=s.nextDouble();//x1,x2,y1,y2为第一个矩形的坐标
		double y1=s.nextDouble();
		double x2=s.nextDouble();
		double y2=s.nextDouble();
		double x3=s.nextDouble();//x3,x4,y3,y4为第二个矩形的坐标
		double y3=s.nextDouble();
		double x4=s.nextDouble();
		double y4=s.nextDouble();
		double m1=max(min(x1,x2),min(x3,x4));//m1,n1交的矩形的左下角坐标
		double n1=max(min(y1,y2),min(y3,y4));
		double m2=min(max(x1,x2),max(x3,x4));//m2,n2交的矩形的右上角坐标
		double n2=min(max(y1,y2),max(y3,y4));
		double area=0.00;
		if(m2>m1&&n2>n1) 
			area=(m2-m1)*(n2-n1);
		DecimalFormat df = new DecimalFormat("#0.00");//精度定义,保留两位小数
		  System.out.print(df.format(area));
		
	}
}

猜你喜欢

转载自blog.csdn.net/weixin_42365095/article/details/85938470