【链接】 我是链接,点我呀:)

【题意】

给你一个n*m的地图。
每个地图为0的时候可以安全走过,且走过后变成1.
(一定要离开之后才会变成1)
而为1的则走过之后会掉入下一层。
你一开始在初始位置(x1,y1);
且你想到达位置(x2,y2);
且要求到达(x2,y2)并且掉进下一层。
保证(x1,y1)的状态为1.
问你可行与否

【题解】

首先如果x1,y1和x2,y2重合。

那么判断一下周围有没有可以走的0状态就好->走过去再走回来

如果没有就无解

如果不重合。

那么首先判断一下(x1,y1)能否到达(x2,y2);

如果不可以则无解。

如果可以

如果x2,y2状态为1,则有解

否则

看一下(x2,y2)周围是否有两个以上的状态为0的点。(要走到(x2,y2)然后出去再回来)

或者只有一个状态为0的点,且(x2,y2)和(x1,y1)相邻 则有解。

否则无解。

【代码】

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int N = 500;
  4. const int dx[4] = {0,0,1,-1};
  5. const int dy[4] = {1,-1,0,0};
  6. int n,m,r1,c1,r2,c2;
  7. char s[N+10][N+10];
  8. bool can[N+10][N+10];
  9. bool bo[N+10][N+10];
  10. int cnt(int x,int y){
  11. int num = 0;
  12. for (int i = 0;i < 4;i++){
  13. int tx = x + dx[i],ty = y + dy[i];
  14. if (tx<1 || tx > n) continue;
  15. if (ty<1 || ty > m) continue;
  16. num += can[tx][ty];
  17. }
  18. return num;
  19. }
  20. void youjie(){
  21. puts("YES");
  22. exit(0);
  23. }
  24. void wujie(){
  25. puts("NO");
  26. exit(0);
  27. }
  28. bool dfs(int x,int y){
  29. if (x==r2 && y == c2) return true;
  30. if (bo[x][y] || (!can[x][y] && !(x==r1 && y==c1))) return false;
  31. bo[x][y] = true;
  32. bool f = false;
  33. for (int i = 0;i < 4;i++){
  34. int tx = x + dx[i],ty = y + dy[i];
  35. f = f|dfs(tx,ty);
  36. }
  37. return f;
  38. }
  39. int main(){
  40. #ifdef LOCAL_DEFINE
  41. freopen("rush_in.txt", "rt", stdin);
  42. #endif
  43. scanf("%d%d",&n,&m);
  44. for (int i = 1;i <= n;i++) scanf("%s",s[i]+1);
  45. for (int i = 1;i <= n;i++)
  46. for (int j = 1;j <= m;j++)
  47. if (s[i][j]=='X')
  48. can[i][j] = 0;
  49. else
  50. can[i][j] = 1;
  51. scanf("%d%d",&r1,&c1);
  52. scanf("%d%d",&r2,&c2);
  53. if (r1 == r2 && c1 == c2){
  54. if (cnt(r1,c1)>0) youjie();
  55. wujie();
  56. }
  57. if (!dfs(r1,c1))
  58. wujie();
  59. else{
  60. if (!can[r2][c2]) youjie();
  61. int cur = cnt(r2,c2);
  62. if (cur > 1) youjie();
  63. if (cur == 1 && (abs(r1-r2)+abs(c1-c2))==1) youjie();
  64. wujie();
  65. }
  66. return 0;
  67. }

【Codeforces Round #301 (Div. 2) C】 Ice Cave的更多相关文章

  1. 【Codeforces Round #301 (Div. 2) E】Infinite Inversions

    [链接] 我是链接,点我呀:) [题意] 给你一个无限长的序列1,2,3,4... 然后给你n个操作. 每个操作ai,bi; 表示调换位置为ai和位置为bi的数的位置. (ai,bi<=10^9 ...

  2. 【Codeforces Round #301 (Div. 2) D】 Bad Luck Island

    [链接] 我是链接,点我呀:) [题意] 剪刀.石头.布各有r,s,p个生活在同一个村子里. 它们两两之间相遇的几率都相同(相遇后就会按照划拳的规则判断输赢,输的人就死掉了). 问你最后只剩下剪刀,只 ...

  3. 【Codeforces Round #301 (Div. 2) B】 School Marks

    [链接] 我是链接,点我呀:) [题意] 已知k门成绩. 总共有n门成绩. 让你构造剩下的n-k门成绩,使得这n门成绩的中位数>=y,并且这n门成绩的和要小于等于x. n为奇数 [题解] 首先判 ...

  4. 【Codeforces Round #301 (Div. 2) A】 Combination Lock

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 模拟水题 [代码] #include <bits/stdc++.h> using namespace std; cons ...

  5. 【Codeforces Round #432 (Div. 1) B】Arpa and a list of numbers

    [链接]h在这里写链接 [题意] 定义bad list是一个非空的.最大公约数为1的序列.给定一个序列,有两种操作:花费x将一个元素删除.花费y将一个元素加1,问你将这个序列变为good list所需 ...

  6. 【Codeforces Round #420 (Div. 2) C】Okabe and Boxes

    [题目链接]:http://codeforces.com/contest/821/problem/C [题意] 给你2*n个操作; 包括把1..n中的某一个数压入栈顶,以及把栈顶元素弹出; 保证压入和 ...

  7. 【Codeforces Round #420 (Div. 2) B】Okabe and Banana Trees

    [题目链接]:http://codeforces.com/contest/821/problem/B [题意] 当(x,y)这个坐标中,x和y都为整数的时候; 这个坐标上会有x+y根香蕉; 然后给你一 ...

  8. 【Codeforces Round #420 (Div. 2) A】Okabe and Future Gadget Laboratory

    [题目链接]:http://codeforces.com/contest/821/problem/A [题意] 给你一个n*n的数组; 然后问你,是不是每个位置(x,y); 都能找到一个同一行的元素q ...

  9. 【Codeforces Round #423 (Div. 2) C】String Reconstruction

    [Link]:http://codeforces.com/contest/828/problem/C [Description] 让你猜一个字符串原来是什么; 你知道这个字符串的n个子串; 且知道第i ...

随机推荐

  1. vim 基础学习之global

    global命令可以在指定模式下,匹配行上进行Ex命令 使用格式: :[range]g[lobal]/{pattern}/[cmd] range-是执行范围(如果缺省,是%) global-命令关键字 ...

  2. js -- 分页功能

    html 代码 <html> <head> <meta charset='utf-8'> <script type="text/javascript ...

  3. 什么是CSS重置,有些什么作用?

    CSS重置是什么? 简单的说就是重置浏览器的CSS默认属性. 为什么要重置它,有什么作用? 因为浏览器的品种很多,每个浏览器的默认样式也是不同的,比如<button>标签,在IE浏览器.F ...

  4. words2

    餐具:coffee pot 咖啡壶coffee cup 咖啡杯paper towel 纸巾napkin 餐巾table cloth 桌布tea -pot 茶壶tea set 茶具tea tray 茶盘 ...

  5. Vagrant 和 docker

    Docker应用实践 http://dockerone.com/article/146 Vagrant 适合用来管理虚拟机,而docker适合用来管理应用环境 http://www.linuxidc. ...

  6. SQL 金额添加千分位

    SELECT CONVERT(NVARCHAR(50),CAST(1000000 AS MONEY),1) SELECT CONVERT(NVARCHAR,CAST(1343432432434.8 A ...

  7. 【DRF认证】

    目录 认证组件的详细用法 本文详细讲述了DRF认证组件的原理以及用法. @ * 源码剖析** 上一篇博客讲解DRF版本的时候我们都知道了,在dispatch方法里执行了initial方法来初始化我们的 ...

  8. Python批量重命名指定目录下文件的两种方法

    #法一 import os path = "C://Python34//" for file in os.listdir(path): if os.path.isfile(os.p ...

  9. Android自己定义圆角ImageView 支持网络图片

    先看下效果图 我们再来看一张CSDN的圆角图片 从布局能够看出csdn app 的头像也是圆角的Image,但能够看到.有明显的毛刺感.不知道是csdn 程序猿的疏忽还是 我手机的问题,本人手机(小米 ...

  10. visibility-控件的显示跟隐藏设置

    在Android开发中,大部分控件都有visibility这个属性,其属性有3个 visible:可见 invisible:不可见,但是会占据原来的位置 gone:不可见,也不会占据原来的位置 可见( ...