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

题解:洛谷 P3397 地毯

【题目来源】

洛谷:P3397 地毯 - 洛谷

【题目描述】

\(n\times n\) 的格子上有 \(m\) 个地毯。

给出这些地毯的信息,问每个点被多少个地毯覆盖。

【输入】

第一行,两个正整数 \(n,m\)。意义如题所述。

接下来 \(m\) 行,每行两个坐标 \((x_1,y_1)\)\((x_2,y_2)\),代表一块地毯,左上角是 \((x_1,y_1)\),右下角是 \((x_2,y_2)\)

【输出】

输出 \(n\) 行,每行 \(n\) 个正整数。

\(i\) 行第 \(j\) 列的正整数表示 \((i,j)\) 这个格子被多少个地毯覆盖。

【输入样例】

5 3
2 2 3 3
3 3 5 5
1 2 1 4

【输出样例】

0 1 1 1 0
0 1 1 0 0
0 1 2 1 1
0 0 1 1 1
0 0 1 1 1

【算法标签】

《洛谷 P3397 地毯》 #枚举# #前缀和#

【代码详解】

#include <bits/stdc++.h>
using namespace std;int n, m;                // n: 矩阵大小,m: 操作次数
int a[1005][1005];       // 二维差分数组int main()
{// 输入矩阵大小和操作次数cin >> n >> m;// 处理每个矩形区域操作while (m--){int x1, y1, x2, y2;cin >> x1 >> y1 >> x2 >> y2;// 对每行进行差分处理for (int i = x1; i <= x2; i++){a[i][y1] += 1;         // 区间起始位置+1a[i][y2 + 1] -= 1;     // 区间结束位置+1处-1}}// 计算前缀和并输出结果矩阵for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){// 计算前缀和得到最终值a[i][j] = a[i][j] + a[i][j - 1];cout << a[i][j] << " ";}cout << endl;}return 0;
}
// 使用acwing模板二刷
#include <bits/stdc++.h>
using namespace std;const int N = 1005;  // 定义矩阵最大尺寸
int n, m;           // n: 矩阵大小,m: 操作次数
int a[N][N];        // 原始矩阵(实际未使用)
int b[N][N];        // 二维差分数组/*** 二维差分数组的插入操作* @param x1 矩形区域左上角x坐标* @param y1 矩形区域左上角y坐标* @param x2 矩形区域右下角x坐标* @param y2 矩形区域右下角y坐标* @param c  要增加的数值*/
void insert(int x1, int y1, int x2, int y2, int c)
{b[x1][y1] += c;         // 左上角+1b[x2 + 1][y1] -= c;     // 左下角外侧-1b[x1][y2 + 1] -= c;     // 右上角外侧-1b[x2 + 1][y2 + 1] += c; // 右下角外侧外侧+1(补偿)
}int main()
{// 输入矩阵大小和操作次数cin >> n >> m;// 处理每个矩形区域操作while (m--){int x1, y1, x2, y2;cin >> x1 >> y1 >> x2 >> y2;insert(x1, y1, x2, y2, 1);  // 对指定区域+1}// 计算二维前缀和,还原最终矩阵for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){b[i][j] += b[i - 1][j] + b[i][j - 1] - b[i - 1][j - 1];}}// 输出结果矩阵for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){cout << b[i][j] << " ";}cout << endl;}return 0;
}

【运行结果】

5 3
2 2 3 3
3 3 5 5
1 2 1 4
0 1 1 1 0
0 1 1 0 0
0 1 2 1 1
0 0 1 1 1
0 0 1 1 1
http://www.jsqmd.com/news/392437/

相关文章:

  • 题解:洛谷 P2367 语文成绩
  • 孤能子视角:全国女婿回丈母娘家 全国儿媳在婆家的统一状态
  • 深入解析:Transformer 大模型架构深度解析(2)RNN 循环神经网络模型在 NLP 中的应用
  • 踩下电门的时候有没有想过,你脚下的电流到底经历了多少层运算?今天咱们扒开某新能源车企研发部的仿真模型,看看他们怎么用Simulink把电动车拆解得明明白白
  • AI大模型学习路线图:小白也能轻松入门,内含收藏资源包!AI大模型学习路线及相关资源推荐
  • 小白/程序员必看:2026年AI大模型生产力转型与Agentic AIOps落地指南
  • Qwen3.5:开启智能体时代,收藏这份国产大模型学习指南!
  • 2026年Q1宁波靠谱装修设计公司盘点:口碑榜单大公开 - 疯一样的风
  • 题解:洛谷 P1314 [NOIP 2011 提高组] 聪明的质监员
  • 大模型算法岗平均月薪达6.8w?程序员小白转行必看:AI大模型训练师的机遇与未来
  • AI入坑指南:收藏这份岗位选择攻略,小白也能快速找到适合你的方向
  • Android开发工程师面试题与答案集
  • 企业H5站点升级PWA (九)
  • 题解:洛谷 P1719 最大加权矩形
  • 题解:洛谷 P8218 【深进1.例1】求区间和
  • 题解:洛谷 P1069 [NOIP 2009 普及组] 细胞分裂
  • Android Framework 开发工程师
  • AI原生应用个性化定制,提升产品差异化
  • 价值投资的核心原则:安全边际
  • 惊!生成随机数居然不用随机数库?4行代码吃透随机本质
  • RabbitMQ在大数据数据可视化中的应用
  • 题解:洛谷 P1593 因子和
  • 数据产品国际化:多语言与多地区支持方案
  • 细胞生物化学仿真软件:VCell_(3).用户界面和基本操作
  • 一文搞懂【RAG技术】- 趣味解读RAG 高效召回秘籍之索引扩展:核心原理+实战案例
  • 细胞生物化学仿真软件:VCell_(1).VCell软件概述
  • 企业H5站点升级PWA (八)
  • 题解:洛谷 P1072 [NOIP 2009 提高组] Hankson 的趣味题
  • 移动开发领域 Gradle 与 CI_CD 的集成方案
  • 题解:洛谷 P1029 [NOIP 2001 普及组] 最大公约数和最小公倍数问题