P1141 01迷宫 dfs连通块
题目描述
有一个仅由数字000与111组成的n×nn \times nn×n格迷宫。若你位于一格0上,那么你可以移动到相邻444格中的某一格111上,同样若你位于一格1上,那么你可以移动到相邻444格中的某一格000上。
你的任务是:对于给定的迷宫,询问从某一格开始能移动到多少个格子(包含自身)。
输入输出格式
输入格式:
第111行为两个正整数n,mn,mn,m。
下面nnn行,每行nnn个字符,字符只可能是000或者111,字符之间没有空格。
接下来mmm行,每行222个用空格分隔的正整数i,ji,ji,j,对应了迷宫中第iii行第jjj列的一个格子,询问从这一格开始能移动到多少格。
输出格式:
mmm行,对于每个询问输出相应答案。
输入输出样例
说明
所有格子互相可达。
对于20%20\%20%的数据,n≤10n≤10n≤10;
对于40%40\%40%的数据,n≤50n≤50n≤50;
对于50%50\%50%的数据,m≤5m≤5m≤5;
对于60%60\%60%的数据,n≤100,m≤100n≤100,m≤100n≤100,m≤100;
对于100%100\%100%的数据,n≤1000,m≤100000n≤1000,m≤100000n≤1000,m≤100000。
这题想清楚了就很简单了,就是让你求连通块,在同一个连通块里的能移动的格子是一样的。需注意的是,这个连通块是指的01连通块,就是从一个位置一直可以走到的地方统称为连通块。
#include <stdio.h>
#include <stdlib.h>
#include <cstring>
#include<queue>
using namespace std;
int n,m,ans,cux,cuy;
char b[1010][1010];
int a[1010][1010];
int vis[1010][1010];
int t[4][2]={0,1,1,0,0,-1,-1,0};
int gx[1010][1010],gy[1010][1010],gene[1010][1010];
{
vis[x][y]=1;
gx[x][y]=cux;
gy[x][y]=cuy;
ans++;
for(int i=0;i<4;i++)
{
int tx=x+t[i][0];
int ty=y+t[i][1];
if(vis[tx][ty]) continue;
if(a[tx][ty]==a[x][y]) continue;
// printf("%d %d\n",tx,ty);
dfs(tx,ty);
}
}
{
memset(gx,0,sizeof(gx));
memset(gy,0,sizeof(gy));
memset(gene,0,sizeof(gene));
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%s",b[i]+1);
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
a[i][j]=b[i][j]-48;
}
}
while(m--)
{
int x1,y1;
scanf("%d%d",&x1,&y1);
if(gx[x1][y1]&&gy[x1][y1])
{
printf("%d\n",gene[gx[x1][y1]][gy[x1][y1]]);
continue;
}
ans=0;
cux=x1;
cuy=y1;
dfs(x1,y1);
printf("%d\n",ans);
gene[x1][y1]=ans;
}
}
P1141 01迷宫 dfs连通块的更多相关文章
- P1141 01迷宫(连通块模板)
题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任务是:对于给定的迷宫, ...
- P1141 01迷宫 DFS (用并查集优化)
题目描述 有一个仅由数字00与11组成的n \times nn×n格迷宫.若你位于一格0上,那么你可以移动到相邻44格中的某一格11上,同样若你位于一格1上,那么你可以移动到相邻44格中的某一格00上 ...
- 洛谷 - P1141 - 01迷宫 - dfs
https://www.luogu.org/problemnew/show/P1141 能互相到达的格子的答案自然是一样的,第一次dfs标记联通块,第二次dfs把cnt传递到整个联通卡并顺手消除vis ...
- 洛谷——P1141 01迷宫
P1141 01迷宫 题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任 ...
- luogu P1141 01迷宫 x
P1141 01迷宫 题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任 ...
- [洛谷Luogu]P1141 01迷宫[联通块 并查集]
题目链接 大致题意 相邻格子不同为连通,计算每个点所在的连通块大小. 想法 我采用了并查集的做法. 开一个辅助数组记录连通块大小,每次合并的时候更新父亲节点的大小即可. 一个点先与它上面的点判定,若判 ...
- DFS(连通块) ZOJ 2743 Bubble Shooter
题目传送门 题意:从炮台射出一个球,三个及以上颜色相同的会掉落,问最后会掉落多少个球 分析:先从炮台找一个连通块,然后与顶部连接的连通块都不会掉落,剩下的就是炮台射出后跟随掉落的. #include ...
- Codeforces Round #375 (Div. 2)——D. Lakes in Berland(DFS连通块)
D. Lakes in Berland time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- 洛谷 P1141 01迷宫
看似普通的 bfs 题(实际上也不怎么难 主要是我太菜了) 题目链接:https://www.luogu.org/problemnew/show/P1141 如果直接用简单的bfs一顿求的话,会超时( ...
随机推荐
- WebApi开启CORS支持跨域POST
概念:CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing).它允许浏览器向跨源服务器,发出XMLHttpRequest请求 ...
- Josephus Problem的详细算法及其Python、Java实现
笔者昨天看电视,偶尔看到一集讲述古罗马人与犹太人的战争--马萨达战争,深为震撼,有兴趣的同学可以移步:http://finance.ifeng.com/a/20170627/15491157_0. ...
- Layui上传图片 带接口
layui.use('upload', function () { var upload = layui.upload; upload.render({ elem: '#LAY_avatarUploa ...
- git+github/码云+VSCode (转载)
VSCode中使用git,参见. Git安装 在初次使用时如果本地没有安装git会提示先安装git,然后重启vscode. 一.本地操作项目前提: 1)若本地没有git拉取下来的项目,用git克隆 ...
- Java高级类特性(一)
一.继承性 1)继承的使用:权限修饰符 class A extends B{}:2)子类:A 父类(基类 SuperClass):B3)子类继承父类后,父类中声明的属性.方法,子类都可以获取到明确:当 ...
- MATLAB indexing question
Question: I have a matrix, for example A = [ 1 2 3; 4 5 6; 7 8 9] ; and a vector of size 1x3 which s ...
- java设计模式-----12、外观模式
Facade模式也叫外观模式,是由GoF提出的23种设计模式中的一种.Facade模式为一组具有类似功能的类群,比如类库,子系统等等,提供一个一致的简单的界面.这个一致的简单的界面被称作facade. ...
- API接口规范V1.0——制定好规范,才好合作开发
返回码规范: 统一六位 000000 表示成功! 参数相关返回码预留100000-199999:系统相关返回码预留200000-299999:数据中心310000-319999后续项目以此类推,后续根 ...
- css的一些细节
1.中文符号居中效果 对于动态输出文字可以不用在意,某些页面可能会有类似提示文案的地方,用英文标点符号,对于居中效果比较友好. 2.元素的上下间距 布局的时候从上往下开始写页面,一般都是写下一个的元素 ...
- Installing Fonts programatically C#
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...