蓝桥杯javaB组 矩形总面积

题目链接:矩形总面积

题目的意思是,在一个坐标系中给定两个矩形R1,R2,他们的状态可能是:R1 和 R2 没有重叠区域;其中一个矩形完全在另一个矩形内部;R1 和 R2 有重叠区域。然后计算两个矩形的总面积。这感觉就是一道数学问题,我们可以分别计算这两个矩形面积相加,如果他们有重叠部分则减去重叠部分的面积。那么重叠部分的面积怎么求就变成这道题的关键了。两个矩形的重叠部分肯定是矩形,所以我们只需求出重叠矩形的长和高就可以了。

简单画了一下重叠的状态,那么就可以求出来长和高了,length=Math.min(ax2,bx2)-Math.max(ax1,bx1),high=min(ay2,by2)-Math.max(ay1,by1);这是有重叠的情况,我们还要考虑没有重叠状态的情况。没有重叠状态时length为0,high也为0;综合考虑这两种情况,最后length=Math.max(0,Math.min(ax2,bx2)-Math.max(ax1,bx1));

high=Math.max(0,Math.min(ay2,by2)-Math.max(ay1,by1));

整体代码如下

public class Main {
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		int ax1 = scanner.nextInt();
        int ay1 = scanner.nextInt();
        int ax2 = scanner.nextInt();
        int ay2 = scanner.nextInt();
        int bx1 = scanner.nextInt();
        int by1 = scanner.nextInt();
        int bx2 = scanner.nextInt();
        int by2 = scanner.nextInt();
        int length=Math.max(0,Math.min(ax2,bx2)-Math.max(ax1,bx1));
        int high=Math.max(0,Math.min(ay2,by2)-Math.max(ay1,by1));
        long area=(long)(ax2-ax1)*(ay2-ay1)+(long)(bx2-bx1)*(by2-by1);
        if(length>0&&high>0){
            area-=(long)length*(long)high;
        }
        System.out.println(area);
	}
}

需要注意的是,结果不要用int类型的数据!!!!,要转long!!!!

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值