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

解题思路:

1:把两个矩形的对角线都化成,左下---右上的对角线 (代码 23、24 行)

2:把两个对角线的坐标大小排好序,让 (a1,b1) 是 最左下的点。 (26、27行,手动模拟、琢磨一下)

3:如果 (c1,d1) 在对角线为 (a1,b1) 、(a2,b2) 的 矩形的内部,那么这两个矩形就是相交的,反之不然。

如图:

AC代码:

cpp 复制代码
#include <stdio.h>

void swap(int &x,int &y)
{
    if ( x > y) 
    {
        int t = x;
        x = y;
        y = t;
    }
}

int main()
{
    int k;
    int a1,a2,b1,b2;
    int c1,c2,d1,d2;
    scanf("%d",&k);
    while ( k-- )
    {
        scanf("%d %d %d %d",&a1,&b1,&a2,&b2);
        scanf("%d %d %d %d",&c1,&d1,&c2,&d2);
        swap(a1,a2);    swap(b1,b2);  //a1,b1 在左下角, a2,b2 在右上角 
        swap(c1,c2);    swap(d1,d2);  //都化成 (左下,右上) 的对角线

        swap(a1,c1);    swap(a2,c2);  //小中取大:c1,大中取小:a2; 比较横坐标; 
        swap(b1,d1);    swap(b2,d2);  //同理;                    比较纵坐标; 
        if (c1 < a2 && d1 < b2)   puts ("Yes");
        else                      puts ("No"); 
    }
    return 0;
} 
相关推荐
PownShanYu3 分钟前
RainbowDash 的 Robot
算法
Phoebe鑫20 分钟前
数据结构每日一题day11(链表)★★★★★
数据结构·算法
独好紫罗兰37 分钟前
洛谷题单3-P2669 [NOIP 2015 普及组] 金币-python-流程图重构
开发语言·python·算法
跳跳糖炒酸奶41 分钟前
第四章、Isaacsim在GUI中构建机器人(3):添加摄像头和传感器
人工智能·python·算法·ubuntu·机器人
Jay_See44 分钟前
Leetcode——239. 滑动窗口最大值
java·数据结构·算法·leetcode
肠胃炎1 小时前
真题246—矩阵计数
java·线性代数·算法·矩阵·深度优先
什码情况1 小时前
微服务集成测试 -华为OD机试真题(A卷、JavaScript)
javascript·数据结构·算法·华为od·机试
罗西的思考3 小时前
[2W字长文] 探秘Transformer系列之(23)--- 长度外推
人工智能·算法
算AI21 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
hyshhhh1 天前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉