题目描述

有一个仅由数字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行,对于每个询问输出相应答案。

输入输出样例

输入样例#1: 复制

2 2
01
10
1 1
2 2
输出样例#1: 复制

4
4

说明

所有格子互相可达。

对于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 <iostream>
#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];
void dfs(int x,int y)
{
    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(tx<1||ty<1||tx>n||ty>n) continue;
        if(vis[tx][ty]) continue;
        if(a[tx][ty]==a[x][y]) continue;
//        printf("%d %d\n",tx,ty);
        dfs(tx,ty);
    }
}
int main()
{
    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连通块的更多相关文章

  1. P1141 01迷宫(连通块模板)

    题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任务是:对于给定的迷宫, ...

  2. P1141 01迷宫 DFS (用并查集优化)

    题目描述 有一个仅由数字00与11组成的n \times nn×n格迷宫.若你位于一格0上,那么你可以移动到相邻44格中的某一格11上,同样若你位于一格1上,那么你可以移动到相邻44格中的某一格00上 ...

  3. 洛谷 - P1141 - 01迷宫 - dfs

    https://www.luogu.org/problemnew/show/P1141 能互相到达的格子的答案自然是一样的,第一次dfs标记联通块,第二次dfs把cnt传递到整个联通卡并顺手消除vis ...

  4. 洛谷——P1141 01迷宫

    P1141 01迷宫 题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任 ...

  5. luogu P1141 01迷宫 x

    P1141 01迷宫 题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任 ...

  6. [洛谷Luogu]P1141 01迷宫[联通块 并查集]

    题目链接 大致题意 相邻格子不同为连通,计算每个点所在的连通块大小. 想法 我采用了并查集的做法. 开一个辅助数组记录连通块大小,每次合并的时候更新父亲节点的大小即可. 一个点先与它上面的点判定,若判 ...

  7. DFS(连通块) ZOJ 2743 Bubble Shooter

    题目传送门 题意:从炮台射出一个球,三个及以上颜色相同的会掉落,问最后会掉落多少个球 分析:先从炮台找一个连通块,然后与顶部连接的连通块都不会掉落,剩下的就是炮台射出后跟随掉落的. #include ...

  8. 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 ...

  9. 洛谷 P1141 01迷宫

    看似普通的 bfs 题(实际上也不怎么难 主要是我太菜了) 题目链接:https://www.luogu.org/problemnew/show/P1141 如果直接用简单的bfs一顿求的话,会超时( ...

随机推荐

  1. checkbox在vue中的用法总结

    前言 关于checkbox多选框是再常见不过的了,几乎很多地方都会用到,这两天在使用vue框架时需要用到checkbox多选功能,实在着实让我头疼,vue和原生checkbox用法不太一样, 之前对于 ...

  2. spring boot(二): spring boot+jdbctemplate+sql server

    前言 小项目或者做demo时可以使用jdbc+sql server解决即可,这篇就基于spring boot环境使用jdbc连接sql server数据库,和spring mvc系列保持一致. 在sp ...

  3. 用Visual Studio Code写Node.j

    介绍 vsc的宣传语是: 一个运行于 Mac OS X.Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器. 按它说的,vsc特别适合来作为前端开发编辑器. 内 ...

  4. Docker常用命令(二)

    Docker常用命令 查看Docker所有正在运行的容器 docker ps 查看Docker已退出的容器 docker ps -a 查看Docker所有镜像 docker images 删除镜像 删 ...

  5. Spring基于注解和XML混合方式的使用

    首先要明白,基于注解和XML两种方式的实现功能是一样的,只是两种不同的配置方式. 一.IoC配置 1.配置xml 在使用注解与xml结合的方式配置IoC之前,首先要引入context标签: xmlns ...

  6. SQL Server 创建和修改数据表

    一.CREATE语句(创建) 1.创建DataBase 1.CONTAINMENT SQL Server 2012 新功能 , 默认值是OFF .(太高级 书上也没有详细介绍). 2.ON ON用于两 ...

  7. HTML中body与html的关系

    转载自张鑫旭-鑫空间-鑫生活[http://www.zhangxinxu.com] 一.相关基础 一个div块级元素没有主动为其设置宽度和高度,浏览器会为其分配可使用的最大宽度(比如全屏宽度),但是不 ...

  8. 随机生成n个不重复的数,范围是2-32,并让其在新页面打开

    var n = 5 var timer; function suiji(){ var arr = [] // 循环生成n个随机数 for(var i=0;i<n;i++){ var num = ...

  9. GIS基础知识

    投影转换 若两者地理坐标系不一致,需要设置七参数进行转换. 不同地方,七参数大小不一样,需要通过计算得到.

  10. Android事件总线(二)EventBus3.0源码解析

    1.构造函数 当我们要调用EventBus的功能时,比如注册或者发送事件,总会调用EventBus.getDefault()来获取EventBus实例: public static EventBus ...