这题犯了一个很严重的错误,bfs 应该在入队操作的同时标记访问,而不是每次只标记取出的队首元素。

题目链接:https://codeforces.com/contest/1365/problem/D

题意

有一个 $n \times m$ 的迷宫,迷宫有四种方格:

  • '.' 空方格
  • '#' 墙
  • 'B' 坏人
  • 'G' 好人

人与人间可以通行,人与墙间不能,可以把任意空方格变为墙,问能否所有好人可以到达 $(n, m)$ 但所有坏人不能。

题解

无解有两种情况:

  • 坏人与好人相邻
  • 在每个坏人相邻的四个方格建墙后有好人不能到达终点

用 bfs 或 dfs 模拟即可。

代码

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int dir[4][2] = {{-1, 0}, {0, -1}, {1, 0}, {0, 1}};
  4. const int N = 55;
  5.  
  6. int n, m;
  7. char MP[N][N];
  8.  
  9. bool inside(int x, int y) {
  10. return (1 <= x and x <= n) and (1 <= y and y <= m);
  11. }
  12.  
  13. bool good(int x, int y) {
  14. return MP[x][y] == '.' or MP[x][y] == 'G';
  15. }
  16.  
  17. void bfs() {
  18. queue<pair<int, int>> que;
  19. que.push({n, m});
  20. MP[n][m] = 'E';
  21. while (!que.empty()) {
  22. int x = que.front().first;
  23. int y = que.front().second;
  24. que.pop();
  25. for (int i = 0; i < 4; i++) {
  26. int nx = x + dir[i][0];
  27. int ny = y + dir[i][1];
  28. if (inside(nx, ny) and good(nx, ny)) {
  29. que.push({nx, ny});
  30. MP[nx][ny] = 'E';
  31. }
  32. }
  33. }
  34. }
  35.  
  36. void solve() {
  37. cin >> n >> m;
  38. vector<pair<int, int>> G, B;
  39. for (int i = 1; i <= n; i++) {
  40. for (int j = 1; j <= m; j++) {
  41. cin >> MP[i][j];
  42. if (MP[i][j] == 'G') G.push_back({i, j});
  43. if (MP[i][j] == 'B') B.push_back({i, j});
  44. }
  45. }
  46. bool block = true;
  47. for (auto pr : B) {
  48. int x = pr.first;
  49. int y = pr.second;
  50. for (int i = 0; i < 4; i++) {
  51. int nx = x + dir[i][0];
  52. int ny = y + dir[i][1];
  53. if (MP[nx][ny] == 'G') block = false;
  54. if (MP[nx][ny] == '.') MP[nx][ny] = '#';
  55. }
  56. }
  57. if (good(n, m)) bfs();
  58. bool escape = true;
  59. for (auto pr : G)
  60. escape &= MP[pr.first][pr.second] == 'E';
  61. cout << (block and escape ? "Yes" : "No") << "\n";
  62. }
  63.  
  64. int main() {
  65. int t; cin >> t;
  66. while (t--) solve();
  67. }

Codeforces Round #648 (Div. 2) D. Solve The Maze的更多相关文章

  1. Codeforces Round #648 (Div. 2) B. Trouble Sort

    一开始读错题了...想当然地认为只能相邻元素交换...(然后换了两种写法WA了4发,5分钟切A的优势荡然无存) 题目链接:https://codeforces.com/contest/1365/pro ...

  2. Codeforces Round #648 (Div. 2) A. Matrix Game

    题目链接:https://codeforces.com/contest/1365/problem/A 题意 给出一个 $n \times m$ 的网格,两人轮流选择一个所在行列没有 $1$ 的方块置为 ...

  3. Codeforces Round #648 (Div. 2)

    链接 : https://codeforces.com/contest/1365/problems problem A 统计可用的行和列的最小值, 模2输出即可 /* * Author: RoccoS ...

  4. Codeforces Round #648 (Div. 2) E. Maximum Subsequence Value(鸽巢原理)

    题目链接:https://codeforces.com/problemset/problem/1365/E 题意 有 $n$ 个元素,定义大小为 $k$ 的集合值为 $\sum2^i$,其中,若集合内 ...

  5. Codeforces Round #648 (Div. 2) C. Rotation Matching

    题目链接:https://codeforces.com/contest/1365/problem/C 题意 有两个大小为 $n$ 的排列,可以循环左移或右移任意次,问最多有多少对同一值在同一位置. 题 ...

  6. Codeforces Round #648 (Div. 2) E. Maximum Subsequence Value 贪心

    题意:E.Maximum Subsequence Value 题意: 给你n 个元素,你挑选k个元素,那么这个 k 集合的值为 ∑2i,其中,若集合内至少有 max(1,k−2)个数二进制下第 i 位 ...

  7. Codeforces Round #648 (Div. 2) F. Swaps Again

    题目链接:F.Swaps Again 题意: 有两个长度为n的数组a和数组b,可以选择k(1<=k<=n/2)交换某一个数组的前缀k和后缀k,可以交换任意次数,看最后是否能使两个数组相等 ...

  8. Codeforces Round #614 (Div. 2) C - NEKO's Maze Game

    题目链接:http://codeforces.com/contest/1293/problem/C 题目:给定一个 2*n的地图,初始地图没有岩浆,都可以走, 给定q个询问,每个询问给定一个点(x,y ...

  9. Codeforces Round #614 (Div. 1) A. NEKO's Maze Game (思维,模拟)

    题意:有一个\(2\)X\(n\)的矩阵,你想从\((1,1)\)走到\((2,n)\),每次可以向上下左右四个方向走,但在某些时间段某个点会被堵住,如果已经被堵住,那么即恢复正常,每次对某个点操作, ...

随机推荐

  1. mac配置Android SDK

    下载地址:http://tools.android-studio.org/index.php/sdk 2.找到tools文件夹 选中android-sdk-macosx包下的tools文件夹,按com ...

  2. 安装Tomcat 9

    文章目录 访问Tomcat官网 选择下载所需的软件包 安装Tomcat 测试安装 访问Tomcat官网 Tomcat官方的下载地址为:https://tomcat.apache.org/downloa ...

  3. 【Linux】salt的cmd.script命令介绍

    salt是一个很棒的自动化运维工具之一,常用的有cmd.run,今天介绍的是cmd.script 其实一眼就能看出这个命令是执行脚本的命令 具体操作如下: 1.将/etc/salt/master中的 ...

  4. 什么是xss攻击

    概述: XSS攻击是Web攻击中最常见的攻击方法之一,它是通过对网页注入可执行代码且成功地被浏览器 执行,达到攻击的目的,形成了一次有效XSS攻击,一旦攻击成功,它可以获取用户的联系人列 表,然后向联 ...

  5. MySQL全面瓦解18:自定义函数

    定义 我们之前学习了MySQL的内置函数,非常丰富,满足了我们对数据操作的大部分需求. 但是如果有一些复杂的业务逻辑在数据库层面就可以完成,无需在程序层面完成的时候,这时候就可以写成MySQL自定义函 ...

  6. 前端开发好帮手,eslint配置全知道

    eslint让人又爱又恨,原因在于它的默认配置非常严格,动则一个小提示就直接报错不给运行.而在开发调试的过程中,我们想时时得到运行效果,它的严格又很烦. 在安装eslint后,我们可以在package ...

  7. 5V充8.4V,5V升压8.4V给电池充电的芯片电路

    5V充8.4V的锂电池,需要把USB口的5V输入,升压转换成8.4V来给两串电池充电. 5V升压8.4V给锂电池充电的专门充电IC 集成了5V升压8.4V电路和充电管理电路的PL7501C 如果不需要 ...

  8. 事件循环Event loop到底是什么

    摘要:本文通过结合官方文档MDN和其他博客深入解析浏览器的事件循环机制,而NodeJS有另一套事件循环机制,不在本文讨论范围中.process.nextTick和setImmediate是NodeJS ...

  9. PWN_ret2text,ret2syscall,ret2shellcode

    首先了解下Linux中的保护机制(具体的绕过等后续再说) 1.canary(栈保护) 在函数开始时就随机产生一个值,将这个值CANARY放到栈上紧挨ebp的上一个位置,当攻击者想通过缓冲区溢出覆盖eb ...

  10. HTML部分

    1.说一下<label>标签的用法 label标签主要是方便鼠标点击使用,扩大可点击的范围,增强用户操作体验 2.说一下事件代理? 事件委托是指将事件绑定到目标元素的父元素上,利用冒泡机制 ...