news 2026/6/10 17:57:16

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/6/10 15:53:15

Open-AutoGLM到底有多强:3个真实场景验证其提效真实性

第一章&#xff1a;Open-AutoGLM的技术演进与核心优势Open-AutoGLM 是新一代开源自动化通用语言模型框架&#xff0c;融合了大模型推理优化、任务自适应调度与多模态协同处理能力。其设计目标是解决传统GLM模型在复杂业务场景下响应延迟高、资源消耗大、泛化能力弱等问题&#…

作者头像 李华
网站建设 2026/6/9 22:41:51

【AI自动化运维新突破】:Open-AutoGLM实时问题响应技术全解析

第一章&#xff1a;Open-AutoGLM问题反馈响应速度概述Open-AutoGLM 作为一个面向自动化代码生成与自然语言理解的开源大语言模型框架&#xff0c;其社区活跃度和问题响应效率直接影响开发者的使用体验。响应速度不仅体现在首次回复的时间上&#xff0c;还包括问题闭环的平均周期…

作者头像 李华
网站建设 2026/6/9 23:13:34

【AI模型部署效率革命】:Open-AutoGLM安装包压缩7大核心技术

第一章&#xff1a;Open-AutoGLM 安装包体积压缩的革命性意义在深度学习模型快速迭代的背景下&#xff0c;Open-AutoGLM 作为一款面向自动化自然语言理解的开源框架&#xff0c;其安装包体积的优化成为影响部署效率与资源消耗的关键因素。通过引入先进的依赖精简机制与模型量化…

作者头像 李华
网站建设 2026/6/10 12:17:24

【Open-AutoGLM响应速度优化】:揭秘问题反馈延迟的5大根源及提速策略

第一章&#xff1a;Open-AutoGLM响应速度优化概述在大规模语言模型应用中&#xff0c;响应速度直接影响用户体验与系统吞吐能力。Open-AutoGLM作为基于AutoGLM架构的开源实现&#xff0c;其推理延迟和并发处理能力成为部署场景中的关键指标。优化响应速度不仅涉及模型本身的计算…

作者头像 李华
网站建设 2026/6/9 15:20:00

Excalidraw多人实时协作机制原理解析

Excalidraw多人实时协作机制原理解析 在远程协作日益成为常态的今天&#xff0c;一个看似简单的“白板”工具&#xff0c;往往能决定一场头脑风暴是高效推进还是陷入混乱。当团队成员分散在全球各地&#xff0c;如何让每个人都能在同一块画布上自由表达、即时反馈&#xff1f;…

作者头像 李华
网站建设 2026/6/10 14:54:49

力扣刷题:反转链表Ⅱ

题目&#xff1a; 给你单链表的头指针 head 和两个整数 left 和 right &#xff0c;其中 left < right 。请你反转从位置 left 到位置 right 的链表节点&#xff0c;返回 反转后的链表 。 示例 1&#xff1a;输入&#xff1a;head [1,2,3,4,5], left 2, right 4 输出&…

作者头像 李华