每日一题(小白)模拟娱乐篇12

图形题要么你思维好,要么直接画个图很容易看出规律!我比较菜所以我画图

正常情况:无相交,直接进行计算(x2-x1)*(y2-y1)+(x4-x3)*(y4-y3)

特殊的情况,特殊情况是x1小于x4且x3<x2。也就是说上面的矩形的左下角y轴必定低于下面矩形的右上角,且上面矩形的右上角x轴必定大于下面矩形的左下角,但是同样也不能低于下面y轴或者大于右边的x轴(其中一种)。说简单点就是判断有无相交部分,若有则减掉一次即可。

具体的相交四种情况如上图所示,红色图形和蓝色图形是相对而言的。

如果你看完还是很懵逼不要紧,先把原来的面积计算出来,接着排序,相交时只需要判断哪个比较大,用大的减去小的就可以得到高和宽。

最重要的就是把两个矩形的位置确定好,这里我们使用Lambda表达式。👇

复制代码
Arrays.sort(arr,(x,y)->Integer.compare(x[0],y[0]));

相对而言左边的总是在arr【0】,接下来的你就可以用你的方法尝试解决。

无论哪种情况绿色矩形左边x轴最小,选取黄色和绿色最小的右边x轴减去即可得到宽。 高度情况有两种,所以都需要判断,用上面较大的y轴减去下面较大的y轴即可。就算绿色矩形在黄色矩形里面依然

粗黄色即为可能的小x轴,粗红色必定为大x轴,所以宽必定为红绿中的最大x-黄x

以此类推

代码如下👇
复制代码
	public static void main(String[] args) {
		Scanner scanner =new Scanner(System.in);
		int[][] arr=new int[2][4];
		for (int i = 0; i < 2; i++) {
			for (int j = 0; j < 4; j++) {
				arr[i][j]=scanner.nextInt();
			}
		}
		Arrays.sort(arr,(x,y)->Long.compare(x[0],y[0]));
		long area=(arr[0][2]-arr[0][0])*(arr[0][3]-arr[0][1])+
				(arr[1][2]-arr[1][0])*(arr[1][3]-arr[1][1]);//计算面积
		if (arr[1][0]>=arr[0][2]) {//右边矩形右下y点和左边矩形右上x点
			System.out.println(area);
		}else {
			int w=Math.min(arr[0][2],arr[1][2])-arr[1][0];//右边减左边 
			int h=Math.min(arr[0][3],arr[1][3])-Math.max(arr[0][1],arr[1][1]);//(上减下)
			area-=w*h;
			System.out.println(area);
		}
		
		
		scanner.close();
				
	}

留了BUG,请检查

相关推荐
每日新鲜事17 小时前
Saucony索康尼携手品牌代言人蔡徐坤推出 KINVARA 1 系列 续写百年世家底蕴,共启先锋表达新章
娱乐
永霖光电_UVLED2 天前
Cree LED 推出一款专为满足现代园艺和农业照明需求红光LED
大数据·汽车·制造·娱乐
程序员老邢2 天前
【人生底稿・番外篇 05】我的电影江湖:从录像带时代,到港片陪伴的青春岁月
java·程序人生·职场发展·娱乐
每日新鲜事2 天前
讲述光影交织下的时尚叙事 波司登“多面登场”2026北京国际电影节光影风尚开幕大秀在京举行
娱乐
EasyDSS4 天前
私有化音视频系统/视频直播点播EasyDSS社交娱乐场景下的一站式音视频技术实践
音视频·娱乐
阿亮爱学代码4 天前
AAOS(Android Automotive OS)IVI(车机娱乐信息系统)相关的简单讲解
娱乐·aaos·automotive·基础知识
永霖光电_UVLED8 天前
宽带圆偏振光(CPL)探测器的技术归纳、以及对未来应用
人工智能·生成对抗网络·汽车·娱乐·激光
永霖光电_UVLED8 天前
纳米级精度可视化微生物与衰老大脑细胞之间的相互作用
大数据·人工智能·物联网·汽车·娱乐
永霖光电_UVLED9 天前
Polar Light 获得了欧盟Eurostars计划的110万欧元(€1.1m)资助
大数据·人工智能·物联网·汽车·娱乐
永霖光电_UVLED9 天前
ams OSRAM 将娱乐与工业灯具业务出售给 Ushio
娱乐