news 2026/5/13 7:00:48

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/5/12 21:39:24

掌握这4项Open-AutoGLM高级技巧,团队人效翻倍不是梦

第一章&#xff1a;Open-AutoGLM 技术支持效率提升的底层逻辑 Open-AutoGLM 作为新一代自动化生成语言模型框架&#xff0c;其核心优势在于通过动态推理链构建与上下文感知优化&#xff0c;显著提升了技术支持场景下的响应效率与准确率。该框架融合了多模态输入解析、意图识别增…

作者头像 李华
网站建设 2026/5/5 7:21:26

Open-AutoGLM成功率统计算法实战应用(稀缺内部资料流出)

第一章&#xff1a;Open-AutoGLM成功率统计算法概述 Open-AutoGLM 是一种面向自动化生成语言模型任务的成功率评估框架&#xff0c;其核心在于通过结构化指标量化模型在多轮推理、指令遵循与上下文理解等关键维度的表现。该算法结合动态采样与置信区间估计&#xff0c;提升统计…

作者头像 李华
网站建设 2026/5/10 3:48:26

为什么你的Open-AutoGLM响应总滞后?这7种常见瓶颈必须排查

第一章&#xff1a;Open-AutoGLM响应延迟问题的全局认知Open-AutoGLM作为一款基于自回归语言模型的自动化推理引擎&#xff0c;在高并发场景下可能出现显著的响应延迟。理解其延迟成因需从系统架构、计算负载与调度机制三方面综合分析。延迟并非单一模块所致&#xff0c;而是多…

作者头像 李华
网站建设 2026/5/12 15:39:08

RabbitMQ消息队列从入门到高可用集群实战

前言 在分布式系统中&#xff0c;消息队列是解耦服务、削峰填谷的核心组件。RabbitMQ作为最流行的开源消息中间件之一&#xff0c;以其稳定性和丰富的功能被广泛使用。本文将从零开始&#xff0c;带你掌握RabbitMQ的核心概念和生产级部署。 一、为什么需要消息队列 1.1 典型…

作者头像 李华
网站建设 2026/5/12 6:22:11

揭秘Open-AutoGLM性能瓶颈:如何通过5项关键指标实现3倍推理加速

第一章&#xff1a;Open-AutoGLM 性能测试指标细化在评估 Open-AutoGLM 模型的实际表现时&#xff0c;需建立一套细粒度的性能测试指标体系&#xff0c;以全面衡量其推理能力、响应效率与稳定性。这些指标不仅服务于模型迭代优化&#xff0c;也为部署场景下的资源调度提供数据支…

作者头像 李华
网站建设 2026/5/12 22:11:56

还在人工充值?Open-AutoGLM已实现百万级订单无人值守处理

第一章&#xff1a;Open-AutoGLM话费充值自动化的变革意义在数字化服务快速演进的背景下&#xff0c;Open-AutoGLM技术为话费充值领域带来了根本性变革。该系统融合大语言模型&#xff08;LLM&#xff09;与自动化执行框架&#xff0c;实现了从用户请求识别到充值操作完成的全链…

作者头像 李华