Problem Description
The doggie
found a bone in an ancient maze, which fascinated him a lot.
However, when he picked it up, the maze began to shake, and the
doggie could feel the ground sinking. He realized that the bone was
a trap, and he tried desperately to get out of this maze.



The maze was a rectangle with sizes N by M. There was a door in the
maze. At the beginning, the door was closed and it would open at
the T-th second for a short period of time (less than 1 second).
Therefore the doggie had to arrive at the door on exactly the T-th
second. In every second, he could move one block to one of the
upper, lower, left and right neighboring blocks. Once he entered a
block, the ground of this block would start to sink and disappear
in the next second. He could not stay at one block for more than
one second, nor could he move into a visited block. Can the poor
doggie survive? Please help him.
Input
The input
consists of multiple test cases. The first line of each test case
contains three integers N, M, and T (1 < N, M < 7; 0 < T
< 50), which denote the sizes of the maze and the time at which
the door will open, respectively. The next N lines give the maze
layout, with each line containing M characters. A character is one
of the following:



'X': a block of wall, which the doggie cannot enter;

'S': the start point of the doggie;

'D': the Door; or

'.': an empty block.



The input is terminated with three 0's. This test case is not to be
processed.
Output
For each test
case, print in one line "YES" if the doggie can survive, or "NO"
otherwise.
Sample Input
4 4 5
S.X.
..X.
..XD
....
3 4 5
S.X.
..X.
...D
0 0 0
Sample Output
NO
YES
题意:小狗找出口,给你一个n*m的地图和小狗,门的位置,让你小狗能否刚好在t时到达门口;
解题思路:刚开始想的是用广搜求出最小时间,如果最小时间
另外还可以加一个剪枝条件,当然了不加这个也能AC,(n*m-s<=t),t过大的时候肯定不能按时到达了;
感悟:深搜好些但是,剪枝不好写啊,不剪枝就会超时,好烦的!
代码:
#include

#include

#include

#include

#include

#define maxn 205

using namespace std;

int visit[maxn][maxn];//这个是记录步数的不是记录走没走的不能用布尔型

char mapn[maxn][maxn];

int n,m,t,direction[4][2]={{1,0},{-1,0},{0,1},{0,-1}};

int sx,sy,dx,dy;

bool flag;

void dfs(int x,int y,int time)

{

   
if(x<1||x>n||y<1||y>m)//边界

       
return;

   
if(flag==1)

       
return;

   
if(x==dx&&y==dy&&time==t)//找到D了

    {

       
if(time=t)

           
flag=1;

       
return;

    }

    int
temp=(t-time)-abs(x-dx)-abs(y-dy);//奇偶性剪枝

   

   
if(temp<0||temp&1)  return;

   

   

    for(int
i=0;i<4;i++)

    {

       
int x1=x+direction[i][0];

       
int y1=y+direction[i][1];

       
if(mapn[x1][y1]!='X')

       
{

           
mapn[x1][y1]='X';

           
dfs(x1,y1,time+1);

           
mapn[x1][y1]='.';//不满足条件的话就返回

       
}

    }

   
return;

}

int main()

{

    int
s=0;

   
//freopen("in.txt", "r", stdin);

   
while(~scanf("%d%d%d\n",&n,&m,&t)&&n&&m&&t)

{

       
flag=s=0;

       
for(int i=1;i<=n;i++)

       
{

           
for(int j=1;j<=m;j++)

           
{

               
scanf("%c",&mapn[i][j]);

               
if(mapn[i][j]=='S')

               
{

                   
sx=i;

                   
sy=j;//狗的位置

               
}

               
if(mapn[i][j]=='D')

               
{

                   
dx=i;

                   
dy=j;//门的位置

               
}

               
if(mapn[i][j]=='X')

                   
s++;

           
}

           
scanf("\n");

       
}

       
mapn[sx][sy]='X';

       
memset(visit,0,sizeof(visit));

       
//for(int i=1;i<=n;i++)

       
//{

       
//    for(int
j=1;j<=m;j++)

       
//    {

       
//       
printf("%c",mapn[i][j]);

       
//    }

       
//   
printf("\n");

       
//}

       
if (n*m-s<=t)//提前判断t过大的情况避免再去搜

       
{

           
printf("NO\n");

           
continue;

       
}

       
dfs(sx,sy,0);

       
//printf("最少走 %d 秒 有 %d 秒\n",ans,t);

       
if(flag)

           
printf("YES\n");

       
else

           
printf("NO\n");

    }

}

Tempter of the Bone的更多相关文章

  1. hdu.1010.Tempter of the Bone(dfs+奇偶剪枝)

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  2. ZOJ 2110 Tempter of the Bone

    Tempter of the Bone Time Limit: 2 Seconds      Memory Limit: 65536 KB The doggie found a bone in an ...

  3. hdu 1010:Tempter of the Bone(DFS + 奇偶剪枝)

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  4. HDU 1010 Tempter of the Bone --- DFS

    HDU 1010 题目大意:给定你起点S,和终点D,X为墙不可走,问你是否能在 T 时刻恰好到达终点D. 参考: 奇偶剪枝 奇偶剪枝简单解释: 在一个只能往X.Y方向走的方格上,从起点到终点的最短步数 ...

  5. Hdu 1010 Tempter of the Bone 分类: Translation Mode 2014-08-04 16:11 82人阅读 评论(0) 收藏

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  6. hdoj 1010 Tempter of the Bone【dfs查找能否在规定步数时从起点到达终点】【奇偶剪枝】

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  7. Tempter of the Bone(dfs+奇偶剪枝)

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  8. hdu 1010 Tempter of the Bone 深搜+剪枝

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  9. Tempter of the Bone(dfs奇偶剪枝)

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  10. ZOJ 2110 Tempter of the Bone(条件迷宫DFS,HDU1010)

    题意  一仅仅狗要逃离迷宫  能够往上下左右4个方向走  每走一步耗时1s  每一个格子仅仅能走一次且迷宫的门仅仅在t时刻打开一次  问狗是否有可能逃离这个迷宫 直接DFS  直道找到满足条件的路径 ...

随机推荐

  1. Numpy中Meshgrid函数介绍及2种应用场景

    近期在好几个地方都看到meshgrid的使用,虽然之前也注意到meshgrid的用法.但总觉得印象不深刻,不是太了解meshgrid的应用场景.所以,本文将进一步介绍Numpy中meshgrid的用法 ...

  2. python 脚本开发实战-当当亚马逊图书采集器转淘宝数据包

    开发环境python2.7.9 os:win-xp exe打包工具pyinstaller 界面tkinter ============================================= ...

  3. Storm同步调用之DRPC模型探讨

    摘要:Storm的编程模型是一个有向无环图,决定了storm的spout接收到外部系统的请求后,spout并不能得到bolt的处理结果并将结果返回给外部请求.所以也就决定了storm无法提供对外部系统 ...

  4. append、extend与insert的区别

    最近在自学Python语言,看到向列表增加更多数据时被append(),extend(),insert()方法绕晕了. 作为编程0基础的小白,觉得有必要自己再梳理一遍: 1.append()方法是指在 ...

  5. poj1014二进制优化多重背包

    Dividing Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 53029   Accepted: 13506 Descri ...

  6. HDU 1754 I Hate It(线段树区间求最值)

    很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师有 ...

  7. 【codevs1001】[bzoj1050]舒适的路线

    给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得路径上最大边和最小边的比值最小. ...

  8. Java历程-初学篇 Day05选择结构(2)

    一,switch 由于本作者学的是jdk6.0版本,我知道7.0可以使用字符串,但是我就不改了 语法: switch(char类型/int类型){ case 值: //输出 break; ... de ...

  9. 想到一个赚钱的APP

    通过APP上发布调查问卷的需求,鼓励人们注册,并给与一定的报酬.需求主要面向一些调查问卷,一类的需求发布

  10. 基于搜狗搜索的微信公众号爬虫实现(C#版本)

    Author: Hoyho Luo Email: luohaihao@gmail.com Source Url:http://here2say.me/11/ 转载请保留此出处 本文介绍基于搜狗的微信公 ...