news 2026/4/15 10:26:54

AtCoder Beginner Contest竞赛题解 | 洛谷 AT_abc436_c 2x2 Placing

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
AtCoder Beginner Contest竞赛题解 | 洛谷 AT_abc436_c 2x2 Placing

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:AtCoder Beginner Contest竞赛题解 | 汇总


【题目来源】

洛谷:[AT_abc436_c ABC436C] 2x2 Placing - 洛谷

【题目描述】

There is a grid with $ N $ rows and $ N $ columns. Let $ (i,j) $ denote the cell at the $ i $ -th row from the top and $ j $ -th column from the left. Initially, nothing is placed on the grid.
有一个N NNN NN列的网格。用( i , j ) (i, j)(i,j)表示从上往下第i ii行、从左往右第j jj列的单元格。初始时,网格上未放置任何物品。

You will now perform $ M $ operations. The $ i $ -th operation $ (1\leq i\leq M) $ is as follows:
现在你将执行M MM次操作。第i ii次操作( 1 ≤ i ≤ M ) (1\leq i\leq M)(1iM)如下:

  • Place a block that occupies a $ 2 \times 2 $ region with cell $ (R_i,C_i) $ as the top-left corner on the grid if and only if its position does not overlap with any other blocks already placed. More precisely, for the set of cells $ S=\lbrace (R_i,C_i),(R_i+1,C_i),(R_i,C_i+1),(R_i+1,C_i+1)\rbrace $ , if there exists a block already placed on the grid that occupies any cell in $ S $ , do nothing; otherwise, place a block that occupies all four cells in $ S $ .
    当且仅当该位置与已放置的任何其他方块不重叠时,将一个占据2 × 2 2 \times 22×2区域且以单元格( R i , C i ) (R_i,C_i)(Ri,Ci)为左上角的方块放置在网格上。更准确地说,对于单元格集合S = { ( R i , C i ) , ( R i + 1 , C i ) , ( R i , C i + 1 ) , ( R i + 1 , C i + 1 ) } S=\lbrace (R_i,C_i),(R_i+1,C_i),(R_i,C_i+1),(R_i+1,C_i+1)\rbraceS={(Ri,Ci),(Ri+1,Ci),(Ri,Ci+1),(Ri+1,Ci+1)},若网格上已存在占据S SS中任一单元格的方块,则什么也不做;否则,放置一个占据S SS中全部四个单元格的方块。

After performing all operations, find how many blocks are placed on the grid.
在执行完所有操作后,求网格上放置的方块数量。

【输入】

The input is given from Standard Input in the following format:

$ N $ $ M $ $ R_1 $ $ C_1 $ $ R_2 $ $ C_2 $ $ \vdots $ $ R_M $ $ C_M $

【输出】

Print the answer.

【输入样例】

4 3 1 1 2 2 2 3

【输出样例】

2

【算法标签】

《洛谷 AT_abc436_c 2x2 Placing》 #模拟#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;typedefpair<int,int>PII;// 定义坐标对类型constintN=200005;// 最大点数(未使用)intn,m;// n: 坐标范围?, m: 操作次数intans;// 答案:不重叠的2×2正方形数量map<PII,int>mp;// 记录每个点是否被占用,1表示被占用intmain(){// 输入n和mcin>>n>>m;// 处理m次操作for(inti=1;i<=m;i++){intx,y;cin>>x>>y;// 输入2×2正方形的左上角坐标// 检查以(x,y)为左上角的2×2正方形是否与已存在的正方形重叠// 一个2×2正方形包含4个点:(x,y), (x,y+1), (x+1,y), (x+1,y+1)// 如果这4个点都没有被占用,说明可以放置新的正方形if(mp[{x,y}]!=1&&// 左上角mp[{x,y+1}]!=1&&// 右上角mp[{x+1,y}]!=1&&// 左下角mp[{x+1,y+1}]!=1)// 右下角{// 可以放置新正方形ans++;// 增加计数// 标记这4个点为已占用mp[{x,y}]=1;mp[{x,y+1}]=1;mp[{x+1,y}]=1;mp[{x+1,y+1}]=1;// 注意:这里没有检查坐标是否越界// 假设输入的坐标都在有效范围内}}// 输出不重叠的正方形数量cout<<ans<<endl;return0;}

【运行结果】

4 3 1 1 2 2 2 3 2
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 10:20:13

我是这样“忽悠”开发写单测的:共赢的艺术

从“强制”到“共赢”的转变 在软件开发的世界中&#xff0c;单元测试&#xff08;简称单测&#xff09;常被视为测试人员的“独舞”——开发人员往往因时间压力或认知偏差而视其为额外负担&#xff0c;导致单测覆盖率低、代码质量隐忧频现。作为一名资深软件测试工程师&#…

作者头像 李华
网站建设 2026/4/12 13:52:02

任务中断不再怕,手把手教你实现Open-AutoGLM精准进度保存

第一章&#xff1a;任务中断不再怕&#xff0c;Open-AutoGLM进度保存全解析在长时间运行的自动化任务中&#xff0c;意外中断是开发者最头疼的问题之一。Open-AutoGLM 提供了一套完整的进度保存与恢复机制&#xff0c;确保即使在系统崩溃或手动终止后&#xff0c;也能从断点继续…

作者头像 李华
网站建设 2026/4/8 19:51:38

2、Windows系统应用操作与个性化设置全攻略

Windows系统应用操作与个性化设置全攻略 1. 安装应用程序 在Windows系统中,若系统未预装所需应用,可通过不同途径获取并安装应用。以下为你详细介绍不同来源应用的安装方法: - 从Windows应用商店安装 : 1. 点击“开始”按钮; 2. 点击“应用商店”,也可直接点击任务…

作者头像 李华
网站建设 2026/4/15 4:01:07

0基础 学习网络编程你需要知道的最基础的一些概念(IP 端口 TCP协议)

什么是网络编程呢?既然提到了网络 ,那么网络带给我们最方便的事情就是进行交流 ,即使相隔万里 ,只要有网络有信号 ,我们就可以交流 ,网络更淡化了地域之间的隔阂 ,让人们足不出户就可以轻松地看见世界网络编程()也是同样的作用 ,最基础的功能也就是可以实现不同计算机上运行的…

作者头像 李华
网站建设 2026/4/9 1:38:39

Open-AutoGLM问题响应慢?掌握这3个关键优化点,效率提升90%

第一章&#xff1a;Open-AutoGLM问题响应慢的现状与挑战Open-AutoGLM作为一款基于大语言模型的自动化代码生成工具&#xff0c;在实际应用中逐渐暴露出响应延迟显著的问题。用户在提交复杂任务请求后&#xff0c;系统常需数十秒甚至更长时间才能返回结果&#xff0c;严重影响了…

作者头像 李华
网站建设 2026/4/14 17:16:58

Python爬虫APP程序思维逻辑(附带源码)

请注意&#xff0c;这个示例是假设性的&#xff0c;并不代表任何真实网站或API。在实际使用中&#xff0c;你需要根据目标网站的具体结构来调整代码。环境准备 首先&#xff0c;确保你已经安装了requests和BeautifulSoup。如果没有安装&#xff0c;可以通过以下命令安装&#x…

作者头像 李华