AT2043 [AGC004C] AND Grid
首先可以发现一个很简单的想法,因为最外层是一定不会有 \(\#\) 的,所以可以考虑让第一个网格图将每个连通块的最外层包起来,第二个网格图将就选择这个包内部的所有点即可。
但你发现这个想法是很难实现的,只能去寻找其他的做法了。
继续沿用刚刚将连通块贴着的想法,只不过我们现在都用一条横线贴着连通块。
为了保证联通,我们让两个网格图各自占据第一列和最后一列的所有点,然后将横线连到第一列和最后一列上。
但是这样还是有问题,当两个连通块上下交错一个距离时,两个网格图还是会相交,多个连通块形成这样的结构时,也不能通过选择上下底面贴着联通的办法。
但是上面这个网格图的结构给予了我们提示,能否用这种横线将这一行上的连通块串起来呢?
于此同时,为了避免横线相交的情况,最简单的方法就是让一行只有一种横线。
因为两边是同样重要的,因此需要让两边占的行数尽可能相同。
这样一来,当一个连通块占据两行时,只需要让这几行中出现不同种类的横线即可。
又因为两种横线数量相同,可以考虑直接按照奇偶分布直线。
那么就只需要考虑单占一行的连通块了。
通过上面的构造可以发现,显然会有一遍能直接将这个联通块串起来,而这个连通块的边上一定会是另一种横线,因为 \(i, i + 1\) 不同奇偶。
因此,本题的构造方法已经浮现出来了:
- 令两个网格图分别为 \(A, B\),将第一列分配给 \(A\),最后一列分配给 \(B\),其中对于任意一行 \(i = 2k + 1\) 将 \((i, 2) \sim (i, m - 1)\) 分配给 \(A\),对于 \(i = 2k\) 将 \((i, 2) \sim (i, m - 1)\) 分配给 \(B\)。
时间复杂度 \(O(nm)\)。
#include <bits/stdc++.h>
using namespace std;
#define rep(i, l, r) for (int i = l; i <= r; ++i)
const int N = 500 + 5;
int n, m;
char s[N][N], a[N][N], b[N][N];
int read() {
char c; int x = 0, f = 1;
c = getchar();
while (c > '9' || c < '0') { if(c == '-') f = -1; c = getchar();}
while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int main() {
n = read(), m = read();
rep(i, 1, n) rep(j, 1, m) a[i][j] = b[i][j] = '.';
rep(i, 1, n) {
scanf("%s", s[i] + 1);
rep(j, 1, m) if(s[i][j] == '#') a[i][j] = b[i][j] = '#';
}
rep(i, 1, n) a[i][1] = '#', b[i][m] = '#';
rep(i, 1, n) {
if(i & 1) rep(j, 1, m - 1) a[i][j] = '#';
else rep(j, 2, m) b[i][j] = '#';
}
rep(i, 1, n) {
rep(j, 1, m) printf("%c", a[i][j]);
puts("");
}
puts("");
rep(i, 1, n) {
rep(j, 1, m) printf("%c", b[i][j]);
puts("");
}
return 0;
}
可以发现,本题的构造从难以实现的想法出发,一步步简化到达了一个非常简单并且优秀的做法。
因此,当构造时出现实现困难的问题时,尽量简化流程方法本质不变的情况下往往能找到非常简单的构造方法。
AT2043 [AGC004C] AND Grid的更多相关文章
- [AGC004C] AND Grid [构造]
题面: 传送门 思路: 一眼看上去是一道很迷的题目......直到我发现,红蓝色涂色的过程是互相独立的 而且最外围没有紫色 那么可以这样操作: 最左边一列全部红色,最右边一列全蓝 然后中间的一行红一行 ...
- [agc004c]and grid
别问我为什么咕了两天 题意: 给出一个$H\times W$的网格图A,仅由'.'和'#'构成,边界上没有'#'且至少有一个'#'.构造两个网格图B和C,大小均为$H\times W$,要求A中为'# ...
- NOIp2018模拟赛四十四
加量不加价?! 昨晚看时间变成了3.5h以为终于变成了正常难度,结果还是国家集训队作业... A题看起来很神仙,B题看上去很神仙,C题一看就知道很神仙: 结果发现B是假题,放榜后发现A也是假题,C是Y ...
- AtCoder刷题记录
构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...
- 【题解】AT2043 AND Grid
[题解]AT2043 AND Grid 我们考虑直接构造两个互补的图切分别联通的图,然后原图有的大家都有就构造完成了. #include<iostream> #include<cst ...
- 【agc004C】AND Grid
Portal --> agc004C Description 给你一个\(n*m\)的网格图\(A\),有一些格子是'#',现在要构造出两个新的网格图\(B\)和\(C\)满足: 1.如果\(A ...
- AT2043 AND Grid 构造
正解:构造 解题报告: 传送门传送门! 这题psj讲了俩做法,一个是最常见的解法,还一种还不知道484对的QAQ 然后先把psj讲的不知正确性的做法港下QwQ 大概就是说,第一个图,先把底给染完 然后 ...
- ExtJS 4.2 Grid组件的单元格合并
ExtJS 4.2 Grid组件本身并没有提供单元格合并功能,需要自己实现这个功能. 目录 1. 原理 2. 多列合并 3. 代码与在线演示 1. 原理 1.1 HTML代码分析 首先创建一个Grid ...
- WPF中Grid实现网格,表格样式通用类
/// <summary> /// 给Grid添加边框线 /// </summary> /// <param name="grid"></ ...
随机推荐
- CS5218|DP转HDMI4K30HZ方案|CS5218应用方案
Capstone CS5218是一款单端口HDMI/DVI电平移位器/中继器,具有重新定时功能.它支持交流和直流耦合信号高达3.0-Gbps的操作与可编程均衡和抖动清洗.它包括2路双模DP电缆适配器寄 ...
- <数据结构>XDOJ333.找位置
问题与解答 问题描述 对给定的一个字符串,找出有重复的字符,并给出其位置. 输入格式 输入包括一个由字母和数字组成的字符串,其长度不超过100. 输出格式 可能有多组测试数据,对于每组数据, 按照样例 ...
- 【MySQL作业】分组查询 group by 子句——美和易思分组查询应用习题
点击打开所使用到的数据库>>> 1.按照商品类型分组统计商品数量和平均单价,并按平均单价升序显示. -- 按照商品类型分组统计商品数量和平均单价,并按平均单价升序显示: select ...
- 编写Java程序,使用抽象类和抽象方法构建不同动物的扑食行为,抽象类设计
返回本章节 返回作业目录 需求说明: 不同的动物都有进食的行为,但是在进食前需要捕获到食物后才可以进食. 要求定义一个抽象的动物类,该类中有一个抽象的捕食方法,和一个非抽象的进食方法.在进食方法中调用 ...
- Solon 1.6.12 发布,类似 Spring 的生态体系
关于官网 千呼万唤始出来: https://solon.noear.org .整了一个月多了,总体样子有了...还得不断接着整! 关于 Solon Solon 是一个轻量级应用开发框架.支持 Web. ...
- html基础 表格的相关属性使用
1.1表格的基本标签 语法结构:<table> /*整体包裹部分,包裹多个tr */ <tr> /* 表格的每一个行,包裹td */ <td></td> ...
- WPF 使用 Silk.NET 进行 DirectX 渲染入门
本文告诉大家如何使用 dotnet 基金会新开源的 Silk.NET 库调用 DirectX 进行渲染的方法.此库是对 DirectX 的底层基础封装,用上了 dotnet 和 C# 的各个新特性,相 ...
- Redis OM .NET Redis对象映射框架
Redis OM Redis OM 是 Redis 官方推出的对象映射框架,即:Object Mapping.让开发人员更简单.方便的操作 Redis 数据.Redis 存储的数据抽象为对象映射,支持 ...
- Hadoop HA(高可用) 详细安装步骤
什么是HA? HA是High Availability的简写,即高可用,指当当前工作中的机器宕机后,会自动处理这个异常,并将工作无缝地转移到其他备用机器上去,以来保证服务的高可用.(简言之,有两台机器 ...
- 初识python:格式化输出
使用input函数输入用户值,再使用三种方法格式化输出. #!/user/bin env python # author:Simple-Sir # 20180831 # 格式化输出: name = i ...