当前位置: 首页 > article >正文

油漆面积——蓝桥杯

1.题目描述

X 星球的一批考古机器人正在一片废墟上考古。

该区域的地面坚硬如石、平整如镜。

管理人员为方便,建立了标准的直角坐标系。

每个机器人都各有特长、身怀绝技。它们感兴趣的内容也不相同。

经过各种测量,每个机器人都会报告一个或多个矩形区域,作为优先考古的区域。

矩形的表示格式为 (x1​,y1​,x2​,y2​),代表矩形的两个对角点坐标。

为了醒目,总部要求对所有机器人选中的矩形区域涂黄色油漆。

小明并不需要当油漆工,只是他需要计算一下,一共要耗费多少油漆。

其实这也不难,只要算出所有矩形覆盖的区域一共有多大面积就可以了。

注意,各个矩形间可能重叠。

本题的输入为若干矩形,要求输出其覆盖的总面积。

输入描述

第一行,一个整数 𝑛n,表示有多少个矩形(1≤n≤10000)。

接下来的 n 行,每行有 4 个整数 x1​,y1​,x2​,y2​,空格分开,表示矩形的两个对角顶点坐标 (0≤x1​,y1​,x2​,y2​≤10000)。

输出描述

一行一个整数,表示矩形覆盖的总面积面积。

输入输出样例

示例

输入

3
1 5 10 10
3 1 20 20
2 7 15 17

输出

340

运行限制

  • 最大运行时间:2s
  • 最大运行内存: 256M

2.代码

3.代码解析

这段代码的目的是计算多个矩形覆盖的总面积。具体来说,它通过将每个矩形分解为 1×1 的小方格,并统计这些小方格中有多少个是首次被覆盖的。最终,输出被覆盖的小方格总数。

1. 数组定义和初始化
bool a[10000][10000];
  • 定义了一个布尔类型的二维数组 a,用于标记某个点是否被覆盖。

  • 由于布尔类型占用的空间较小(通常为1字节),因此可以减少内存占用。

2. 输入矩形数量
int n;
cin >> n;
  • 读取矩形的数量 n。

3. 初始化覆盖点计数
int sum = 0;
  • 用于统计被覆盖的小方格总数。

4. 读取每个矩形的坐标
for (int i = 0; i < n; i++) {
    int x1, x2, y1, y2;
    cin >> x1 >> y1 >> x2 >> y2; // 输入矩形的坐标
  • 读取每个矩形的左上角和右下角坐标。

5. 确保坐标顺序
if (x1 > x2) swap(x1, x2); // 确保 x2 >= x1
if (y1 > y2) swap(y1, y2); // 确保 y2 >= y1
  • 通过 std::swap 确保 x1≤x2 和 y1≤y2。

6. 遍历矩形区域
for (int j = x1 + 1; j <= x2; j++) {
    for (int k = y1 + 1; k <= y2; k++) {
        if (!a[j][k]) {
            sum++;
            a[j][k] = true;
        }
    }
}
  • 遍历矩形区域内的每个点 (j,k)。

  • 如果点 (j,k) 未被覆盖(a[j][k] == false),则将其标记为已覆盖(a[j][k] = true),并增加覆盖点计数。

7. 输出结果
cout << sum << endl;
  • 输出被覆盖的小方格总数。


http://www.kler.cn/a/533132.html

相关文章:

  • SQL序列分析法:核心技巧与实战方法论 | 从用户行为分析到工业设备监控的通用解决方案
  • Ubuntu 24.04 安装 Poetry:Python 依赖管理的终极指南
  • Windows图形界面(GUI)-QT-C/C++ - QT Frame
  • SQL范式与反范式_优化数据库性能
  • Unity游戏(Assault空对地打击)开发(6) 鼠标光标的隐藏
  • Docker使用指南(一)——镜像相关操作详解(实战案例教学,适合小白跟学)
  • Chromium132 编译指南 - Android 篇(八):开始编译
  • 记录一次-Rancher通过UI-Create Custom- RKE2的BUG
  • 机器学习入门指南:快速上手与实践
  • Elixir语言的网络编程
  • Netty线上如何做性能调优?
  • 人工智能搜索的层级发展趋势:从信息检索到智能决策
  • Linux网络 | 进入数据链路层,学习相关协议与概念
  • java项目验证码登录
  • Linux 进程终止
  • BUU13 [极客大挑战 2019]BabySQL 1
  • DeepSeek-R1大模型学习笔记
  • 用Python实现SVM分类器:从数据到决策边界可视化,以鸢尾花数据集为例
  • DeepSeek 本地部署全攻略
  • Java使用Jsoup处理报文简单样例
  • CSS in JS
  • 【LeetCode: 922. 按奇偶排序数组 II + 双指针】
  • 个人c项目 java项目解释
  • 力扣 45. 跳跃游戏 II
  • 3. k8s二进制集群之负载均衡器高可用部署
  • 7. k8s二进制集群之Kube ApiServer部署