【洛谷p1162】填涂颜色
(今天yy出奇的不活泼,认真的吓人)
算法标签:

思路啊qwq:
part1:
- 想法是先暴搜出每一行的1,取最前方一个1和最后方一个1,然后中间的0填上色,80分,因为没有考虑到“00011100101”这样类似的的情况。
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<cmath>
using namespace std;
int n,minx=,miny[],maxx,maxy[];
int a[][],ans[][];
bool vis[][];
int dx[]={,,-,};
int dy[]={,,,-};
struct az{
int x,y;
};
az fz(int x,int y){
az rtn;
rtn.x=x;
rtn.y=y;
return rtn;
}
bool pan(int x,int y){
return x>=&&y>=&&x<=n&&y<=n&&vis[x][y]==;
}
queue<az> q;
void bfs(){
q.push(fz(,));
vis[][]=;
int num=;
while(!q.empty()){
az h=q.front();
q.pop();
for(int i=;i<;i++){
int xx=h.x,yy=h.y;
if(pan(xx+dx[i],yy+dy[i])){
xx+=dx[i];
yy+=dy[i];
if(a[xx][yy]==){
ans[++num][]=xx;
ans[num][]=yy;
if(xx<minx)minx=xx;if(xx>maxx)maxx=xx;
if(yy>maxy[xx])maxy[xx]=yy;
if(yy<miny[xx])miny[xx]=yy;
}
q.push(fz(xx,yy));
vis[xx][yy]=;
}
}
}
for(int i=minx;i<=maxx;i++)
for(int j=miny[i];j<=maxy[i];j++)
if(a[i][j]==)
a[i][j]=;
}
int main(){
scanf("%d",&n);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
scanf("%d",&a[i][j]);
memset(miny,,sizeof(miny));
bfs();
for(int i=;i<=n;i++){
for(int j=;j<=n;j++)
cout<<a[i][j]<<" ";
cout<<endl;
}
}然后下载了最后一个数据,我做了一个伟大的打表水数据的决定qwq:

- 但是良心不安啊,于是我又想了一个神奇的思路:
- 根据题意,当找到第一个1时,其右下必然是圈内的0,那么只要从这个0开始广搜寻找联通块就可以了。
- 所以就这这个写了一个程序:
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<cmath>
using namespace std;
int n,sy,sx;
int a[][];
bool vis[][],b;
int dx[]={,,-,};
int dy[]={,,,-};
bool panduan(int x,int y){ }
struct az{
int x,y;
};
az fz(int x,int y){
az rtn;
rtn.x=x;
rtn.y=y;
return rtn;
}
bool pan(int x,int y){
return x>=&&y>=&&x<=n&&y<=n&&vis[x][y]==;
}
queue<az> q;
void bfs(){
q.push(fz(,));
vis[][]=;
int num=;
while(!q.empty()){
az h=q.front();
q.pop();
for(int i=;i<;i++){
int xx=h.x,yy=h.y;
if(a[xx][yy]==){
sx=xx+;
sy=yy+;
b=;
break;
}
if(pan(xx+dx[i],yy+dy[i])){
xx+=dx[i];
yy+=dy[i];
q.push(fz(xx,yy));
vis[xx][yy]=;
}
}
if(b==)break;
}
queue<az> Q;
Q.push(fz(sx,sy));
a[sx][sy]=;
while(!Q.empty()){
az hh=Q.front();
Q.pop();
for(int i=;i<;i++){
int aa=hh.x,bb=hh.y;
aa+=dx[i];
bb+=dy[i];
if(a[aa][bb]==){
Q.push(fz(aa,bb));
a[aa][bb]=;
} }
}
}
int main(){
scanf("%d",&n);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
scanf("%d",&a[i][j]);
bfs();
for(int i=;i<=n;i++){
for(int j=;j<=n;j++)
cout<<a[i][j]<<" ";
cout<<endl;
}
}end-
【洛谷p1162】填涂颜色的更多相关文章
- 洛谷 P1162 填涂颜色 DFS
P1162 填涂颜色 https://www.luogu.com.cn/problem/P1162 qaq搜索好抽象啊,蒟蒻表示难以理解,搞半天才做出来一道题,很挫败www 思路 染色法.找墙壁外的连 ...
- 洛谷P1162—填涂颜色
这应该是是第一次记录洛谷题库里的题目吧: 题目描述 由数字00组成的方阵中,有一任意形状闭合圈,闭合圈由数字11构成,围圈时只走上下左右44个方向.现要求把闭合圈内的所有空间都填写成22.例如:6 \ ...
- 洛谷 P1162 填涂颜色
题目链接:https://www.luogu.org/problemnew/show/P1162 题目描述由数字0组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要 ...
- 洛谷 P1162 填涂颜色【DFS】
题目链接:https://www.luogu.org/problemnew/show/P1162 题目描述 由数字 0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字 1 构成,围圈时只走上下左右 4 ...
- 洛谷—— P1162 填涂颜色
https://www.luogu.org/problem/show?pid=1162 题目描述 由数字0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要求把闭 ...
- 洛谷 P1162 填涂颜色题解
题目描述 由数字00组成的方阵中,有一任意形状闭合圈,闭合圈由数字11构成,围圈时只走上下左右44个方向.现要求把闭合圈内的所有空间都填写成22.例如:6 \times 66×6的方阵(n=6n=6) ...
- 洛谷P1162 填涂颜色【bfs】
题目链接:https://www.luogu.org/problemnew/show/P1162 题意: 有一个0和1组成的矩阵,一些1组成一个闭合圈,圈住一些0,现在要把被圈住的这些0变成2输出. ...
- 洛谷P1162 填涂颜色
题目链接:https://www.luogu.org/problemnew/show/P1162 这道题是LITTLESUN写的第一道BFS哦! 对于这道题的的思路是把封闭图形外边的0标记一边,在最后 ...
- 洛谷 - P1162 - 填涂颜色 - 简单搜索
https://www.luogu.org/problemnew/show/P1162 在外面加一圈0把0连起来,然后把所有0换成2,再从(0,0)把连通的2全部改回来. 这也是一个判断内外圈的好办法 ...
- luogu P1162 填涂颜色 x
P1162 填涂颜色 题目描述 由数字0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字1构成,围圈时只走上下左右4个方向.现要求把闭合圈内的所有空间都填写成2.例如:6X6的方阵(n=6),涂色前和 ...
随机推荐
- CentOS7 源码编译安装Tengine
简介 Tengine是由淘宝网发起的Web服务器项目.它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性.它的目的是打造一个高效.安全的Web平台. 发展 Tengine的性能和 ...
- Linq组合查询与分页组合查询结合
1.组合查询 <div>姓名:<asp:TextBox ID="T1" runat="server"></asp:TextBox& ...
- UDP广播-缓冲区过小
上次介绍到了关于客户端实时刷新摄像头所识别的图片的一些方法,采用了了UDP广播的技术做处理.理论上是没有问题的,将客户端运行在不同电脑上也能很好的看到效果,运行日志也没看出啥问题,结果今天翻看日志的时 ...
- CLASS类继承
单继承:# class People: 经典类class People(object): #新式类 def __init__(self,name,age,n=1000): self.name = na ...
- CCF CSP 201503-1 图像旋转 (降维)
题目链接:http://118.190.20.162/view.page?gpid=T27 问题描述 试题编号: 201503-1 试题名称: 图像旋转 时间限制: 5.0s 内存限制: 256.0M ...
- C# Thread.Jion()
什么是进程? 当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源. 而一个进程又是由多个线程所组成的. 什么是线程? 线程是程序中的一个执行流,每个线程都有自己的 ...
- 5.JAVA基础复习——JAVA中的static关键字作用与用法
static关键字: 特点: 1.static是一个修饰符,用于修饰成员.(成员变量,成员函数)static修饰的成员变量 称之为静态变量或类变量. 2.static修饰的成员被所有的对象共享. 3. ...
- Centos 7 安装 ELK 5.6.8 及基础的配置
下载 wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.6.8.rpm wget https://ar ...
- Bresenham算法
1 算法原理 基本原理从某处摘得:设直线方程为yi+1=yi+k(xi+1-xi)+k.假设列坐标象素已经确定为xi,其行坐标为yi.那么下一个象素的列坐标为xi+1,而行坐标要么为yi,要么递增1为 ...
- Bigger-Mai 养成计划,Python基础巩固三
1.集合的基本操作(set)集合是一个无序的,不重复的元素集合,他的主要作用是去重:把一个列表变为集合就自动去重了.关系测试:测试两组数据之间的交集,差集,并集等关系 list_1 = [1,4,6, ...