标签:arr min max 面积 蓝桥 arr2 矩形 Math
问题描述
平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴。对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积。
输入格式
输入仅包含两行,每行描述一个矩形。
在每行中,给出矩形的一对相对顶点的坐标,每个点的坐标都用两个绝对值不超过10^7的实数表示。
输出格式
输出仅包含一个实数,为交的面积,保留到小数后两位。
样例输入
1 1 3 3
2 2 4 4
样例输出
1.00
我的思路:
就画图硬写。
代码:
package LangQiao;
import java.io.BufferedInputStream;
import java.util.Scanner;
/**
* Copyright (C), 2019-2021, Kkoo
* Author: kkoo
* Date: 2021/11/12 11:17 下午
* FileName: 矩形面积交
*/
public class 矩形面积交 {
public static void main(String[] args) {
Scanner in = new Scanner(new BufferedInputStream(System.in));
//使用arr 存储两个矩形的相对坐标
double[][] arr = new double[2][4];
//使用arr2 存储相交部分的坐标
double[] arr2 = new double[4];
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[0].length; j++) {
arr[i][j] = in.nextDouble();
}
}
//求相交部分的坐标 x1 y1 x2 y2
arr2[0] = Math.max(Math.min(arr[0][0], arr[0][2]), Math.min(arr[1][0], arr[1][2]));
arr2[1] = Math.max(Math.min(arr[0][1], arr[0][3]), Math.min(arr[1][1], arr[1][3]));
arr2[2] = Math.min(Math.max(arr[0][0], arr[0][2]), Math.max(arr[1][0], arr[1][2]));
arr2[3] = Math.min(Math.max(arr[0][1], arr[0][3]), Math.max(arr[1][1], arr[1][3]));
//判断矩形是否正确
if (arr2[0] < arr2[2] && arr2[1] < arr2[3]) {
System.out.printf("%.2f\n", (arr2[2] - arr2[0]) * (arr2[3] - arr2[1]));
} else {
System.out.println("0.00");
}
}
}
标签:arr,min,max,面积,蓝桥,arr2,矩形,Math 来源: https://blog.csdn.net/Kkooe/article/details/121298411
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。