题目描述

有一个仅由数字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:
复制

  1. 2 2
  2. 01
  3. 10
  4. 1 1
  5. 2 2
输出样例#1: 复制

  1. 4
  2. 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。

m询问的次数比较大,那么我们应该预处理出答案,然后O(1)的回答;

可以发现,联通块内的点的答案是一样的,所以我们先处理出联通块,然后记录即可;

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<string>
  7. #include<cmath>
  8. #include<map>
  9. #include<set>
  10. #include<vector>
  11. #include<queue>
  12. #include<bitset>
  13. #include<ctime>
  14. #include<time.h>
  15. #include<deque>
  16. #include<stack>
  17. #include<functional>
  18. #include<sstream>
  19. //#include<cctype>
  20. //#pragma GCC optimize(2)
  21. using namespace std;
  22. #define maxn 200005
  23. #define inf 0x7fffffff
  24. //#define INF 1e18
  25. #define rdint(x) scanf("%d",&x)
  26. #define rdllt(x) scanf("%lld",&x)
  27. #define rdult(x) scanf("%lu",&x)
  28. #define rdlf(x) scanf("%lf",&x)
  29. #define rdstr(x) scanf("%s",x)
  30. #define mclr(x,a) memset((x),a,sizeof(x))
  31. typedef long long ll;
  32. typedef unsigned long long ull;
  33. typedef unsigned int U;
  34. #define ms(x) memset((x),0,sizeof(x))
  35. const long long int mod = 1e9 + 7;
  36. #define Mod 1000000000
  37. #define sq(x) (x)*(x)
  38. #define eps 1e-5
  39. typedef pair<int, int> pii;
  40. #define pi acos(-1.0)
  41. //const int N = 1005;
  42. #define REP(i,n) for(int i=0;i<(n);i++)
  43. typedef pair<int, int> pii;
  44.  
  45. inline int rd() {
  46. int x = 0;
  47. char c = getchar();
  48. bool f = false;
  49. while (!isdigit(c)) {
  50. if (c == '-') f = true;
  51. c = getchar();
  52. }
  53. while (isdigit(c)) {
  54. x = (x << 1) + (x << 3) + (c ^ 48);
  55. c = getchar();
  56. }
  57. return f ? -x : x;
  58. }
  59.  
  60. ll gcd(ll a, ll b) {
  61. return b == 0 ? a : gcd(b, a%b);
  62. }
  63. int sqr(int x) { return x * x; }
  64.  
  65. /*ll ans;
  66. ll exgcd(ll a, ll b, ll &x, ll &y) {
  67. if (!b) {
  68. x = 1; y = 0; return a;
  69. }
  70. ans = exgcd(b, a%b, x, y);
  71. ll t = x; x = y; y = t - a / b * y;
  72. return ans;
  73. }
  74. */
  75.  
  76. int n, m;
  77. int dx[] = { 0,0,1,-1 };
  78. int dy[] = { 1,-1,0,0 };
  79. int Map[1002][1002];
  80. bool chk(int x, int y) {
  81. return x >= 1 && x <= n && y >= 1 && y <= n;
  82. }
  83.  
  84. int Ans[1000002][2];
  85. char ch[1002][1002];
  86. int vis[1002][1002];
  87. int tot;
  88. int dp[1002][1002];
  89. void dfs(int x, int y) {
  90. tot++;
  91. Ans[tot][0] = x; Ans[tot][1] = y;
  92. for (int i = 0; i < 4; i++) {
  93. int nx = x + dx[i];
  94. int ny = y + dy[i];
  95. if (chk(nx, ny) && !vis[nx][ny] && ch[nx][ny] != ch[x][y]) {
  96. vis[nx][ny] = 1;
  97. dfs(nx, ny);
  98. }
  99. }
  100. }
  101.  
  102. int main()
  103. {
  104. // ios::sync_with_stdio(0);
  105. n = rd(); m = rd();
  106. for (int i = 1; i <= n; i++)scanf("%s", ch[i] + 1);
  107. for (int i = 1; i <= n; i++) {
  108. for (int j = 1; j <= n; j++) {
  109. if (!vis[i][j]) {
  110. vis[i][j] = 1; tot = 0;
  111. dfs(i, j);
  112. for (int k = 1; k <= tot; k++)dp[Ans[k][0]][Ans[k][1]] = tot;
  113. }
  114.  
  115. }
  116. }
  117. for (int i = 1; i <= m; i++) {
  118. int x = rd(), y = rd();
  119. printf("%d\n", dp[x][y]);
  120. }
  121. return 0;
  122. }

01迷宫 BFS的更多相关文章

  1. 01迷宫 洛谷 p1141

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

  2. 【u115】&&【t031】 01迷宫

    01迷宫(maze01) Time Limit: 1 second Memory Limit: 128 MB [问题描述] 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相 ...

  3. Codevs 1629 01迷宫

    1629 01迷宫 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题目描述 Description 有一个由01组成的n*n格迷宫,若你位于一格0上,那么你可 ...

  4. luogu P1141 01迷宫 x

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

  5. [LuoguP1141]01迷宫

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

  6. 洛谷——P1141 01迷宫

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

  7. ZOJ 1649 Rescue(有敌人迷宫BFS)

    题意 求迷宫中从a的位置到r的位置须要的最少时间  经过'.'方格须要1s  经过'x'方格须要两秒  '#'表示墙 因为有1s和2s两种情况  须要在基础迷宫bfs上加些推断 令到达每一个点的时间初 ...

  8. 01迷宫题解(bfs,联通块)

    题目https://www.luogu.org/problemnew/show/P1141 这个题解主要针对我个人出现的一些问题和注意的地方. 解题思路 首先说一下联通块 联通块这个比较抽象,举个例子 ...

  9. 洛谷P1141 01迷宫【bfs】

    题目链接:https://www.luogu.org/problemnew/show/P1141 题意: 有一个填了0和1的n*n的格子,只能0走到1,1走到0 有m组询问(数据量是1e5),问某一个 ...

随机推荐

  1. Tomcat内存溢出及大小调整

    一.在使用Java程序从数据库中查询大量的数据或是应用服务器(如tomcat.jboss,weblogic)加载jar包时会出现java.lang.OutOfMemoryError异常.这主要是由于应 ...

  2. code1091 传染病控制

    1.读入图,边是双向的 2.递归建树,同时确定每一层的节点 3.dfs按层搜索,先把这一层所有被传染的(die[pa[k]]=true的)的die置为true 然后循环,每次把一个die为true的变 ...

  3. python3--多目录之间的协作的一些必备知识

    # Auther: Aaron Fan # 动态获取执行文件的相对路径路径:print(__file__) #动态获取执行文件的绝对路径:import osfile_path = os.path.ab ...

  4. jquery设置select选中的文本

    <select id="prov">  <option value="1">北京市</option>  <option ...

  5. Spring框架总结(十一)

    切入点表达式 可以对指定的“方法”进行拦截:从而给指定的方法所在的类生层代理对象. 其他跟十一样,只更改bean.xml <?xml version="1.0" encodi ...

  6. javascript总结47: JS动画原理&jQuery 效果- 各种动画

    1 动画的原理就是: 盒子本身的位置+步长 2 什么是步长? var box=document.getElementById('box'); btn.onclick = function() { // ...

  7. Exception (1) Understanding Exception Handling

    When an exception is thrown, it cannot be ignored--there must be some kind of notification or termin ...

  8. 自制Java中的Mutex类

    同步问题中,一个很重要的问题是同步的域,什么是同步的域呢?简单以 synchronized 这个关键字来说,就是它所同步的范围.并发编程中很多时候出现的问题没有选好同步范围所导致的.但现有的同步关键字 ...

  9. SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)(Finchley版本)

    在上一篇文章讲述zuul的时候,已经提到过,使用配置服务来保存各个服务的配置文件.它就是Spring Cloud Config. 一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管 ...

  10. heartbeat+nginx搭建高可用HA集群

    前言: HA即(high available)高可用,又被叫做双机热备,用于关键性业务.简单理解就是,有2台机器 A 和 B,正常是 A 提供服务,B 待命闲置,当 A 宕机或服务宕掉,会切换至B机器 ...