• LQ0272 矩形运算【计算几何】


    题目来源:蓝桥杯2012初赛 Java A组H题

    题目描述
    在编写图形界面软件的时候,经常会遇到处理两个矩形的关系。

    如图 1 所示,矩形的交集指的是:两个矩形重叠区的矩形,当然也可能不存在(参看图 2 )。两个矩形的并集指的是:能包含这两个矩形的最小矩形,它一定是存在的。

    在这里插入图片描述

    图 1

    在这里插入图片描述

    图 2

    本题目的要求就是:由用户输入两个矩形的坐标,程序输出它们的交集和并集矩形。

    矩形坐标的输入格式是输入两个对角点坐标,注意,不保证是哪个对角,也不保证顺序(你可以体会一下,在桌面上拖动鼠标拉矩形,4 个方向都可以的)。

    输入描述
    数据共两行,每行表示一个矩形。每行是两个点的坐标。x 坐标在左,y 坐标在右。坐标系统是:屏幕左上角为 (0,0),x 坐标水平向右增大;y 坐标垂直向下增大。

    输出描述
    也是两行数据,分别表示交集和并集。如果交集不存在,则输出 NO。

    前边两项是左上角的坐标。后边是矩形的长度和高度。

    输入输出样例
    示例
    输入

    100,220,300,100
    150,150,300,300

    输出

    150,150,150,70
    100,100,200,200

    问题分析
    注意,一个点重叠也算相交。

    AC的C++语言程序如下:

    /* LQ0272 矩形运算 */
    
    #include 
    
    using namespace std;
    
    struct Point {
        int x, y;
    };
    
    int main()
    {
        Point a, b, c, d;
        int x1, y1, x2, y2, x3, y3, x4, y4;
        scanf("%d,%d,%d,%d", &x1, &y1, &x2, &y2);
        scanf("%d,%d,%d,%d", &x3, &y3, &x4, &y4);
    
        a.x = min(x1, x2), a.y = min(y1, y2);
        b.x = max(x1, x2), b.y = max(y1, y2);
        c.x = min(x3, x4), c.y = min(y3, y4);
        d.x = max(x3, x4), d.y = max(y3, y4);
    
        bool flag = true;
        if (b.y < c.y || a.y > d.y || c.x > b.x || d.x < a.x) flag = false;
        int lx, ly, rx, ry;
        if (flag) { // 矩形相交
            // 交集
            lx = max(a.x, c.x), ly = max(a.y, c.y);
            rx = min(b.x, d.x), ry = min(b.y, d.y);
            printf("%d,%d,%d,%d\n", lx, ly, (rx - lx), (ry - ly));
    
            // 并集
            lx = min(a.x, c.x), ly = min(a.y, c.y);
            rx = max(b.x, d.x), ry = max(b.y, d.y);
            printf("%d,%d,%d,%d\n", lx, ly, (rx - lx), (ry - ly));
        } else { // 矩形不相交
            cout << "NO" << endl;
            lx = min(a.x, c.x), ly = min(a.y, c.y);
            rx = max(b.x, d.x), ry = max(b.y, d.y);
            printf("%d,%d,%d,%d\n", lx, ly, (rx - lx), (ry - ly));
        }
    
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
  • 相关阅读:
    【Linux】Linux+Nginx部署项目
    设计模式:责任链模式
    Thinkpad X201i笔记本电脑开机Fan Error
    MindSpore:测试mindspore的ascend用例编译失败
    2022年09月 Python(一级)真题解析#中国电子学会#全国青少年软件编程等级考试
    git配置SSH 公钥
    【Tauri】(5):本地运行candle和 qwen 大模型,并测试速度
    arudino 知识整理
    消息队列的概念和原理
    Redis系列11:内存淘汰策略
  • 原文地址:https://blog.csdn.net/tigerisland45/article/details/128072919