题目的意思是,在一个坐标系中给定两个矩形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!!!!