AT2043 AND Grid 构造
正解:构造
解题报告:
这题psj讲了俩做法,一个是最常见的解法,还一种还不知道484对的QAQ
然后先把psj讲的不知正确性的做法港下QwQ
大概就是说,第一个图,先把底给染完
然后对于所有的要染色的点一直往下拓展直到联通
然后对另一个图先取反一波然后加上原图
听起来似乎挺正确
显然重合部分是原图
而且似乎确实是联通的?
好神仙啊orzorz
我有时间打下补上代码QAQ
然后再把比较常见的那个给说了QwQ
这种解法就是,比较难想(,,,也可能是我比较菜QAQ
但是知道辽这种解法之后就不会忘了QwQ而且很简便
酱婶的,就是,首先我们构俩矩阵
一个只有奇数行涂了色
一个只有偶数行涂了色
然后这个时候它们的交集就是空集咯
然后这个时候,把所有要求的点在两个图上都给涂色
显然交集只会有要求的点且为联通的
好神仙啊我jio得,,,等写完了把代码放上来QAQ
然后通报一个hin烦躁的事儿,,,就是,这题,66个测试点嘛,然后我对了62个,,,好滴趴那也先这样趴,,,我枯了,,,,:D
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define rp(i,x,y) for(register ll i=x;i<=y;++i) int h,w;
bool QwQ[][]; inline ll read()
{
char ch=getchar();ll x=;bool y=;
while(ch!='-' && (ch>'' || ch<''))ch=getchar();
if(ch=='-')ch=getchar(),y=;
while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=getchar();
return y?x:-x;
}
inline char rdch()
{
char ch=getchar();while(ch!='.' && ch!='#')ch=getchar();return ch;
} int main()
{
h=read();w=read();
rp(i,,h)
rp(j,,w)
{
char ch=rdch();
if(ch=='#')QwQ[i][j]=;
}
rp(i,,h)
{
rp(j,,w)
{
if((i&) || QwQ[i][j])printf("#");
else printf(".");
}
printf("\n");
}
printf("\n");
rp(i,,h)
{
rp(j,,w)
{
if(!(i&) || QwQ[i][j])printf("#");
else printf(".");
}
printf("\n");
}
return ;
}
这是那个62/66的代码,,,
upd:
,,,我知道我哪儿错了QAQ
布星太难过了,灵巧为何如此菜啊QAQ
那我就把我的sd错误分享一下QAQ
就是,我上面这个思路听起来484real对!
但是它有个问题,,,
就是你怎么知道它是个联通的鸭QAQ
那如果刚好某行一个#也没有你怎么联通嘛QAQ
于是为了联通,我们就可以
让一个把左边一列全染了
另一个把右边一列全染了
然后就OK!成功达成!
等下放下正解代码QAQ
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define rp(i,x,y) for(register ll i=x;i<=y;++i) int h,w;
bool QwQ[][]; inline ll read()
{
char ch=getchar();ll x=;bool y=;
while(ch!='-' && (ch>'' || ch<''))ch=getchar();
if(ch=='-')ch=getchar(),y=;
while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=getchar();
return y?x:-x;
}
inline char rdch()
{
char ch;cin>>ch;return ch;
} int main()
{
h=read();w=read();memset(QwQ,,sizeof(QwQ));
rp(i,,h)
rp(j,,w){char ch=rdch();if(ch=='#')QwQ[i][j]=;} // cout<<endl<<endl; rp(i,,h)
{
printf("#");
rp(j,,w-)
{
if(i%== || QwQ[i][j]==)printf("#");
else printf(".");
}
if(QwQ[i][w]==)printf("#");else printf(".");
printf("\n");
}
printf("\n");
rp(i,,h)
{
if(QwQ[i][]==)printf("#");else printf(".");
rp(j,,w-)
{
if(i%== || QwQ[i][j] || j==w)printf("#");
else printf(".");
}
printf("#");
printf("\n");
}
return ;
}
这是正解!
AT2043 AND Grid 构造的更多相关文章
- 【题解】AT2043 AND Grid
[题解]AT2043 AND Grid 我们考虑直接构造两个互补的图切分别联通的图,然后原图有的大家都有就构造完成了. #include<iostream> #include<cst ...
- C. Magic Grid 构造矩阵
C. Magic Grid time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- [AGC004C] AND Grid [构造]
题面: 传送门 思路: 一眼看上去是一道很迷的题目......直到我发现,红蓝色涂色的过程是互相独立的 而且最外围没有紫色 那么可以这样操作: 最左边一列全部红色,最右边一列全蓝 然后中间的一行红一行 ...
- Codeforces Global Round 9 B. Neighbor Grid (构造,贪心)
题意:给一个\(n\)X\(m\)的矩阵,矩阵中某个数字\(k\)表示其四周恰好有\(k\)个不为0的数字,你可以使任意位置上的数字变大,如果操作后满足条件,输出新矩阵,否则输出NO. 题解:贪心,既 ...
- AtCoder刷题记录
构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...
- 论文翻译——Dynamic Pooling and Unfolding Recursive Autoencoders for Paraphrase Detection
Dynamic Pooling and Unfolding Recursive Autoencoders for Paraphrase Detection 动态池和展开递归自动编码器的意译检测 论文地 ...
- Minieye杯第十五届华中科技大学程序设计邀请赛网络赛D Grid(简单构造)
链接:https://ac.nowcoder.com/acm/contest/560/D来源:牛客网 题目描述 Give you a rectangular gird which is h cells ...
- AT2043 [AGC004C] AND Grid
首先可以发现一个很简单的想法,因为最外层是一定不会有 \(\#\) 的,所以可以考虑让第一个网格图将每个连通块的最外层包起来,第二个网格图将就选择这个包内部的所有点即可. 但你发现这个想法是很难实现的 ...
- Eos开发——构造查询条件
1.ajax 方式 var data = { orgid :orgid,year:year ,month: month,type:type,sortField:'sellEmpname' ,sortO ...
随机推荐
- 一句话木马:ASP篇
ASP一句话木马收集: <%eval request("chopper")%> <%execute request("chopper")%&g ...
- 怎么打乱List中元素的顺序
使用Collections类中shuffle随机打乱List内部元素顺序 原文地址:http://blog.csdn.net/warren2013/article/details/17414771 / ...
- It is possible that this issue is resolved by uninstalling an existing version of the apk if it is present, and then re-installing ___Error Installing APK
一 : 根据以下路径,找到Instant Run中的选项 File —— Settings——Build,Execution,Deployment——Instant Run ...
- pip导出安装包及批量安装
python导出安装包及版本 pip freeze > requirements.txt 批量安装pip install -r requirements.txt
- python --->字典 集合 学习笔记
1.字典--->创建空字典:dict={} broa=["李宁",”耐克“,“阿迪达斯”,“鱼c工作室”] sloga=[“A”,“B”,“C”,“D”] dict={&qu ...
- 安装ubuntu后,你的屏幕尺寸太小,无法设置,该怎么解决
安装完虚拟机之后,你的Ubuntu可能会在尺寸很小,(这种情况可能有,可能没有) 想要点击设置,选中Display里的分辨率下拉框,但是却因为这个窗口太大,无法点击apply按钮.悲剧啦!!! Ctr ...
- WinPE启动U盘的制作方法与软件下载(通用PE工具箱/老毛桃/大白菜WinPE)
转自:http://blog.sina.com.cn/s/blog_58c380370100cp5x.html 文件大小:39.5M(支持Win7安装,早期的通用PE工具箱,小巧不过几十兆,现在都臃肿 ...
- python基础---->python的使用(一)
这里面记录一些python的一些基础知识,数据类型和变量.幸而下雨,雨在街上泼,却泼不进屋内.人靠在一块玻璃窗旁,便会觉得幸福.这个家还是像个家的. python的一些基础使用 一.python中的数 ...
- 常见的mysql 进程state<转自网络>
Analyzing 线程是对MyISAM 表的统计信息做分析(例如, ANALYZE TABLE ). checking permissions 线程是检查服务器是否具有所需的权限来执行该语句. Ch ...
- Elasticsearch 学习之配置文件详解
Elasticsearch配置文件##################### Elasticsearch Configuration Example ##################### # # ...