基础练习 矩形面积交

资源限制

时间限制:1.0s   内存限制:512.0MB

问题描述

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

输入格式

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

输出格式

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

样例输入

1 1 3 3
2 2 4 4

样例输出

1.00

这个题应该是很简单的,但是感觉被我写复杂了,里面还有几种情况我没有写,emmm~,但是应付蓝桥杯里面的测试用例还是没问题的,亲测有效,将就一下吧,我懒得写了。。。

 


import java.text.DecimalFormat;
import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		double a1,a2,a3,a4;
		double b1,b2,b3,b4;
		Scanner sc=new Scanner(System.in);
		a1=sc.nextDouble();
		a2=sc.nextDouble();
		a3=sc.nextDouble();
		a4=sc.nextDouble();
		b1=sc.nextDouble();
		b2=sc.nextDouble();
		b3=sc.nextDouble();
		b4=sc.nextDouble();
		
		double dx,dy;
		double max1=Math.max(a1, a3);    //最大横坐标
		double min1=Math.min(a1, a3);    //最小横坐标
		
		double max2=Math.max(a2, a4);
		double min2=Math.min(a2, a4);

		
		double max3=Math.max(b1, b3);
		double min3=Math.min(b1, b3);

		double max4=Math.max(b2, b4);
		double min4=Math.min(b2, b4);
		DecimalFormat dlf=new DecimalFormat("0.00");
		double area;
		double zero=0;
		if(max1<=min3||max3<=min1)System.out.print(dlf.format(zero));
		else if(max2<=min4||max4<=min2)System.out.print(dlf.format(zero));
		else if(min1<=min3&max1>=max3) {
			if(max2>=max4&min2<=min4) {
				area=(max3-min3)*(max4-min4);
				System.out.print(dlf.format(area));
			}
			else {
				if(max2<max4) {
					area=(max2-min2)*(max4-min4);
				}
				else {
					area=(max2-min4)*(max4-min4);
				}
			}
		}
		else {
			if(max1<max3)dx = max1-min3;
			else dx=max3-min1;
			if(max2<max4)dy=max2-min4;
			else dy=max4-min2;
			System.out.print(dlf.format(dx*dy));
		}
	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值