题目描述

有一个仅由数字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. Go语言程序结构分析初探

    每一种编程语言都有自己的语法.结构以及自己的风格,这也是每种语言展现各自魅力及众不同的地方.Go也不例外,它简单而优雅,与此同时使用起来也很有趣.在本文中,我们将讨论以下几点: Go程序结构 如何运行 ...

  2. windows环境下pycharm如何设置Linux编码

    最近写代码一直在windows环境下,写完之后再传到Linux端就会出现代码格式错乱. 解决办法: 在windows端的pycharm代码格式设置为unix and os及可以解决这个问题. 如果你要 ...

  3. 【Java基础】9、Enumeration接口和Iterator接口的区别

    package java.util; public interface Enumeration<E> {     boolean hasMoreElements();     E next ...

  4. 【开发工具之eclipse】8、The word is not correctly spelled。强迫症看着很难受

    eclipse出现了极其让我郁闷的错误,"The word is not correctly spelled" 我讨教过一些朋友以后,还是没有得到答案,我就纳闷了.然后我继续将代码 ...

  5. Vim i和a区别

    i是当前位置插入 a是当前文字的后面插入

  6. 深入理解Java 8 Lambda(语言篇)

    State of Lambda by Brian Goetz 原文链接:http://lucida.me/blog/java-8-lambdas-insideout-language-features ...

  7. MEF 插件式开发之 DotNetCore 初体验

    背景叙述 在传统的基于 .Net Framework 框架下进行的 MEF 开发,大多是使用 MEF 1,对应的命名空间是 System.ComponentModel.Composition.在 Do ...

  8. kubectl 常用命令总结

    # 查看所有 pod 列表, -n 后跟 namespace, 查看指定的命名空间 kubectl get pod kubectl get pod -n kube # 查看 RC 和 service ...

  9. sql: Query to Display Foreign Key Relationships and Name of the Constraint for Each Table in Database

    --20170505 --塗聚文 Geovin Du CREATE DATABASE DuMailSystem GO USE DuMailSystem GO --1查詢表的及备注说明 SELECT S ...

  10. 【读书笔记】iOS-iOS视频

    视频多媒体文件主要是存放视频数据信息,视频数据量要远远大于音频数据文件,而且视频编码和解码算法非常复杂,因此早期的计算机由于CPU处理能力差,要采用视频解压卡硬件支持,视频采集和压缩也要采用硬件卡.按 ...