题目描述

平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴。对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积。

输入

输入仅包含两行,每行描述一个矩形。

在每行中,给出矩形的一对相对顶点的坐标,每个点的坐标都用两个绝对值不超过10^7的实数表示。

输出

输出仅包含一个实数,为交的面积,保留到小数后两位。

题解

两个矩形的交就是面积的交,这是属于二维的问题。让我们一步一步出发,先从一维开始推导。(放心,不难_)

一维线段的交:

让我们在这假设有两条线段,小蓝b和小红r,1,2分别为他们的左右端点。

小蓝由左向右运动,小红由右向左运动。

经历阶段

  1. 你我永世不见(不相交)

    让我们细心观察,发现此时 b2<r1

  2. 你我擦肩而过(相交为0)

    细心观察, b1=r1

  3. 你我庆幸相逢(相交)

    观察可得,b1<r1,b2<r2

    但是!由于牵扯到两线段的长短,情况很多,故可根据不相交的区域来间接求得。

  4. 你我曲终人散(相交为0)

    观察again!r2==b1

  5. 你我形同陌路(不相交)

    最后一次look!r2<b1

    接下来让我们结合以上5种情况:

结果不然而喻~

二维矩形求交

让我们请出升级版的小蓝和小红~(长方形和正方形都是矩形哦,这里为了方便,使用的是正方形)

题目输入的是矩形的相对坐标,我们设坐标为分别为

bx1,by1,bx2,by2

rx1,ry1,rx2,ry2

让我们假设他们相交了,进行解题~

我们设黑色矩形的左下角坐标为(hx1,hy1),右上角坐标为(hx2,hy2)。

经过细细推敲我发现如下规律:

hx1=max(min(bx1,bx2),min(rx1,rx2))

hy1=max(min(by1,by2),min(ry1,ry2))

hx2=min(max(bx1,bx2),max(rx1,rx2))

hy2=min(max(by1,by2),max(ry1,ry2))

刚看到这些你可能会懵懵的,但是你举几个例子试试看哦!

你会发现数学真奇妙

但是!什么时候才是不相交呢?我们来个不相交的情况你就懂了!

此时你会发现 hx1>hx2,hy1>hy2!

这就不是相交了,于是输出0,00就行了!

经过漫长的图示,终于可以写代码了!废话少说,代码走起!

(我为了创建更少的变量,使用了数组,相信聪明的你一定会看懂的~)

#include <iostream>
#include <cstdio>
#include <cmath>
#define min(x,y) ((x)<(y)?x:y)
#define max(x,y) ((x)>(y)?x:y)
using namespace std; int main()
{
double a1[4],a2[4],a3[4],area;
//输入数据
for(int i=0;i<4;i++) cin>>a1[i];
for(int i=0;i<4;i++) cin>>a2[i];
//计算相交矩形的左下和右上顶点坐标
a3[0]=max(min(a1[0],a1[2]),min(a2[0],a2[2]));
a3[1]=max(min(a1[1],a1[3]),min(a2[1],a2[3]));
a3[2]=min(max(a1[0],a1[2]),max(a2[0],a2[2]));
a3[3]=min(max(a1[1],a1[3]),max(a2[1],a2[3]));
if(a3[0]>a3[2]||a3[1]>a3[3]){
//一定不相交
printf("0.00");
} else{
area = (abs(a3[2]-a3[0])*abs(a3[3]-a3[1]));
printf("%.2f",area);
}
return 0;
}

小提示

C,C++中经过我的查阅,是没有和double类型相对应的max和min函数的,所以,我这里宏定义了一下~

如果你知道有更好的方法可以在下方评论哦!我看到的话一定会回复你的

【题解】[蓝桥杯] [基础练习VIP]矩形面积交的更多相关文章

  1. 问题 1462: [蓝桥杯][基础练习VIP]Huffuman树

    题目描述 Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0,  p1,  …,  pn-1},用这列数构造Huffman树的过程如下: ...

  2. 问题 1476: [蓝桥杯][基础练习VIP]龟兔赛跑预测 (模拟)

    题目链接 题目描述 话说这个世界上有各种各样的兔子和乌龟,但是 研究发现,所有的兔子和乌龟都有一个共同的特点--喜欢赛跑.于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研 ...

  3. 问题 1936: [蓝桥杯][算法提高VIP]最大乘积

    问题 1936: [蓝桥杯][算法提高VIP]最大乘积 时间限制: 1Sec 内存限制: 128MB 提交: 77 解决: 16 题目描述 对于n个数,从中取出m个数,如何取使得这m个数的乘积最大呢? ...

  4. 2019计蒜之道初赛4 B. 腾讯益智小游戏—矩形面积交(简单)(矩形交集)

    B. 腾讯益智小游戏—矩形面积交(简单) 1000ms 262144K   腾讯游戏开发了一款全新的编程类益智小游戏,最新推出的一个小游戏题目是关于矩形面积交的.聪明的你能解出来吗?看下面的题目接招吧 ...

  5. HDU - 1255 覆盖的面积(线段树求矩形面积交 扫描线+离散化)

    链接:线段树求矩形面积并 扫描线+离散化 1.给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. 2.看完线段树求矩形面积并 的方法后,再看这题,求的是矩形面积交,类同. 求面积时,用被覆 ...

  6. Java实现 蓝桥杯VIP基础练习 矩形面积交

    描述 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴.对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积. 输入 输入仅包含两行,每行描述一个矩形. 在每行中,给出矩 ...

  7. 2015 UESTC 数据结构专题E题 秋实大哥与家 线段树扫描线求矩形面积交

    E - 秋实大哥与家 Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/contest/show/59 De ...

  8. 【hdu1255】线段树求矩形面积交

    题意大概就是上图这个样子.<=100组测试数据,每组<=1000个矩形. 题解: 这个问题怎么解决..做了上一题矩形面积并应该就会了.. 对于每个节点维护3个值: cnt:该节点所代表的这 ...

  9. C语言 · 矩形面积交

    问题描述 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴.对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积. 输入格式 输入仅包含两行,每行描述一个矩形. 在每行中 ...

  10. 51nod1302 矩形面积交

    有2N个矩形,这些矩形被标号为0 ~ 2N-1,对于第i个矩形其长宽分别为X[i]与Y[i].现在要把这2N个矩形分为两组,每组N个,每个矩形恰好分到两组中的一组里.分成两组后,设两组分别为A组.B组 ...

随机推荐

  1. 今日Python练习--正则表达式的相关练习import re

    1.如何利用Python在文本中国提取手机号码 # 如何利用Python在文本中提取手机号码 import re content="白日依山尽,黄河入180320213699999909海流 ...

  2. 【SpringBoot】还不会SpringBoot项目模块分层?来这手把手教你

    前言 缘由 经常看到网上很多优秀的开源项目中,代码简洁,模块分层完美.反观自己代码层级混乱,,却不知如何整理分层.此文手把手教你一步一步创建模块,左手右手一个慢动作.结合本人实际开发及个人项目中分层思 ...

  3. MySQL 索引的种类

    我们知道一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重. 一.平衡多路查 ...

  4. Kafka 之 HW 与 LEO

    更多内容,前往 IT-BLOG HW(High Watermark):俗称高水位,它标识了一个特定的消息偏移量(offset),消费者只能拉取到这个 offset 之前的消息.分区 ISR 集合中的每 ...

  5. leader epoch

    更多内容,前往 IT-BLOG leader epoch 代表 Leader 的纪元信息(epoch),初始值为0.每当 Leader 变更一次,leader epoch 的值就会加1,相当于为 Le ...

  6. 如何使用Photino创建Blazor项目进行跨平台

    Photino是什么 Photino是一组使用Web (HTML/CSS/JavaScript)UI创建桌面应用程序的技术.TryPhotino.io 维护 .NET 构建,并鼓励社区开发 Photi ...

  7. Go - 高并发抢到红包实现

    // utils.gopackage mainimport ( "fmt" "math/rand" "sync" "time&qu ...

  8. Spring(Bean详解)

    GoF之工厂模式 GoF是指二十三种设计模式 GoF23种设计模式可分为三大类: 创建型(5个):解决对象创建问题. 单例模式 工厂方法模式 抽象工厂模式 建造者模式 原型模式 结构型(7个):一些类 ...

  9. 基于docker和cri-dockerd部署k8sv1.26.3

    cri-dockerd是什么? 在 Kubernetes v1.24 及更早版本中,我们使用docker作为容器引擎在k8s上使用时,依赖一个dockershim的内置k8s组件:k8s v1.24发 ...

  10. 验证ADG的坏块检测和自动修复

    环境: Oracle 19c ADG(主库:单实例:备库:RAC) 1.主库新建测试文件 2.主库创建测试表 3.查询表对应数据文件信息 4.模拟数据文件物理坏块 5.查询对应测试表 6.进一步查询日 ...