xtu oj 1178 Rectangle

题目描述

给你两个平行于坐标轴的矩形,请判断两者是不是相交(面积有重合的部分)?

输入

第一行是一个整数K,表示样例数。 每个样例占两行,每行是4个整数,表示一个矩形的对角线点的坐标,坐标值为0到1,000之间。

输出

每个样例输出一个结果,相交输出Yes,否则输出No。

样例输入

复制代码
2
0 0 1 1
1 1 2 2
0 0 2 2
1 1 3 3

样例输出

复制代码
No
Yes

AC代码

cs 复制代码
#include<stdio.h>
int Max(int a,int b){
	if(a>b)return a;
	else return b;
}
int Min(int a,int b){
	if(a>b)return b;
	else return a;
}
int main()
{
	int T;
	scanf("%d",&T);
	while(T--){
		int x1,y1,x2,y2;
		scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
		int x3,y3,x4,y4;
		scanf("%d%d%d%d",&x3,&y3,&x4,&y4);
		double ox1=(x1+x2)/2;//矩形中心坐标值 
		double oy1=(y1+y2)/2;
		double ox2=(x3+x4)/2;
		double oy2=(y3+y4)/2;
		double lx=(Max(x1,x2)-Min(x1,x2)+Max(x3,x4)-Min(x3,x4))/2;//两个矩阵相邻拼起来的一半 
		double ly=(Max(y1,y2)-Min(y1,y2)+Max(y3,y4)-Min(y3,y4))/2;
		double t1=Max(ox1,ox2)-Min(ox1,ox2);//中心坐标差值 
		double t2=Max(oy1,oy2)-Min(oy1,oy2);
		if(t1<lx&&t2<ly){
			printf("Yes\n");
		}
		else printf("No\n");
    }
}

解题思路:如果两个矩形中心点的横纵坐标的差都小于两个矩阵相邻拼接起来的长度的一半,则两个矩形相交。

AC代码

cs 复制代码
#include<stdio.h>
int Max(int a,int b){
	if(a>b)return a;
	else return b;
}
int Min(int a,int b){
	if(a>b)return b;
	else return a;
}
int main()
{
	int T;
	scanf("%d",&T);
	while(T--){
		int x1,y1,x2,y2;
		scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
		int x3,y3,x4,y4;
		scanf("%d%d%d%d",&x3,&y3,&x4,&y4);
		int t1,t2,t3,t4;
		int max1=Max(Min(x1,x2),Min(x3,x4));
		int min1=Min(Max(x1,x2),Max(x3,x4));
		int max2=Max(Min(y1,y2),Min(y3,y4));
		int min2=Min(Max(y1,y2),Max(y3,y4));
		if(max1<min1&&max2<min2){
			printf("Yes\n");
		}
		else printf("No\n");
	}
}
相关推荐
货拉拉技术7 分钟前
大模型音频水印技术:用AI守护音频数据的“身份指纹”
人工智能·算法·安全
ysa05103026 分钟前
利用数的变形简化大规模问题#数论
c++·笔记·算法
奔跑吧邓邓子42 分钟前
【C语言实战(59)】C语言打造你的专属密码管家
c语言·开发实战·密码管家
CoookeCola1 小时前
开源图像与视频过曝检测工具:HSV色彩空间分析与时序平滑处理技术详解
人工智能·深度学习·算法·目标检测·计算机视觉·开源·音视频
DARLING Zero two♡1 小时前
【优选算法】D&C-Mergesort-Harmonies:分治-归并的算法之谐
java·数据结构·c++·算法·leetcode
CoovallyAIHub1 小时前
万字详解:多目标跟踪(MOT)终极指南
深度学习·算法·计算机视觉
张人玉1 小时前
WPF 控件速查 PDF 笔记(可直接落地版)(带图片)
大数据·microsoft·ui·c#·wpf
wudl55661 小时前
Apache Flink Keyed State 详解之一
算法·flink·apache
CoovallyAIHub2 小时前
Arm重磅加码边缘AI!Flexible Access开放v9平台,实现高端算力普惠
深度学习·算法·计算机视觉
louisdlee.2 小时前
树状数组维护DP——前缀最大值
数据结构·c++·算法·dp