http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2110


//2110
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<iostream>
#include<cstdlib>
using namespace std;
int n, m, t, di, dj, flag;
char map[10][10];
int dir[4][2]={{0, 1}, {1, 0}, {0, -1}, {-1, 0}};
void dfs(int si, int sj, int cnt)
{
int i, xx, yy;
if(si<=0||sj<=0||si>n||sj>m) return ;
if(si==di&&sj==dj&&cnt==t)
{
flag=1;
return ;
}
int temp=t-cnt-abs(si-di)-abs(sj-dj);
if(temp<0 || temp%2)
return ;
for(i=0; i<4; i++)
{
xx=si+dir[i][0], yy=sj+dir[i][1];
if(map[xx][yy]!='X')
{
map[xx][yy]='X';
dfs(xx, yy, cnt+1);
if(flag) return;
map[xx][yy]='.';
}
}
return ;
}
int main()
{
int i, j, si, sj;
while(scanf("%d%d%d", &n, &m, &t)!=EOF)
{
if(n==0&&m==0&&t==0) break;
memset(map, 0, sizeof(map));
int wal=0;
char temp;
scanf("%c", &temp);
for(i=1; i<=n; i++)
{
//scanf("%s%*c", map[i]);
for(j=1; j<=m; j++)
{
scanf("%c", &map[i][j]);
if(map[i][j]=='S')
si=i, sj=j;
else if(map[i][j]=='D')
di=i, dj=j;
else if(map[i][j]=='X')
wal++;
}
scanf("%c", &temp);
}
if(n*m-wal<=t)
{
printf("NO\n");
continue;
}
flag=0;
map[si][sj]='X';
dfs(si, sj, 0);
if(flag)
printf("YES\n");
else
printf("NO\n");
}
return 0;
} ****************************************
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<iostream>
#include<cstdlib>
using namespace std;
int n, m, t, dx, dy, flag;
char map[10][10];
int dir[4][2]={{0, 1}, {1, 0}, {0, -1}, {-1, 0}};
void dfs(int x, int y, int step)
{
int i, xx, yy;
if(x<=0||y<=0||x>n||y>m) return ;
if(x==dx&&y==dy&&step==t)
{
flag=1;
return ;
}
int temp=t-step-abs(x-dx)-abs(y-dy);
if(temp<0 || temp%2)
return ;
for(i=0; i<4; i++)
{
xx=x+dir[i][0], yy=y+dir[i][1];
if(map[xx][yy]!='X')
{
map[xx][yy]='X';
dfs(xx, yy, step+1);
if(flag) return;
map[xx][yy]='.';
}
}
return ;
}
int main()
{
int i, j, x, y;
while(scanf("%d%d%d", &n, &m, &t)!=EOF)
{
if(n==0&&m==0&&t==0) break;
memset(map, 0, sizeof(map));
int wal=0;
char temp;
scanf("%c", &temp);
for(i=1; i<=n; i++)
{
//scanf("%s%*c", map[i]);
for(j=1; j<=m; j++)
{
scanf("%c", &map[i][j]);
if(map[i][j]=='S')
x=i, y=j;
else if(map[i][j]=='D')
dx=i, dy=j;
else if(map[i][j]=='X')
wal++;
}
scanf("%c", &temp);
}
if(n*m-wal<=t)
{
printf("NO\n");
continue;
}
flag=0;
map[x][y]='X';
dfs(x, y, 0);
if(flag)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}

  


// zoj  2110

#include <iostream>
#include <string.h>
#include <stdlib.h>
using namespace std; char map[9][9]; //迷宫地图
int n,m,t; //迷宫的大小,及迷宫的门会在第t秒开启
int di,dj; //(di,dj):门的位置
bool escape;
int dir[4][2]={{0,-1},{0,1},{1,0},{-1,0}};//控制行走方向 左 右 下 上
void dfs(int si,int sj,int cnt) //已经到达(si, sj)位置 且已经花费cnt秒 {
int i,temp;
if (si>n||sj>m||si<=0||sj<=0) return; //起点不再矩阵之内。返回 //边界
if (cnt==t&&si==di&&sj==dj) escape=1;// 起点在门处,且门在零秒的时候开启,成功逃生
if (escape) return; temp=(t-cnt)-abs(si-di)-abs(sj-dj);//
if (temp<0||temp&1) return; //temp<0是最短距离小于时间的剪枝,temp&1是奇偶剪枝,还有一种写法,temp%2!=0;
for (i=0;i<4;i++)
{
if (map[si+dir[i][0]][sj+dir[i][1]]!='X')//如果该方格是可以通过的,跳到此空格进行操作
{
map[si+dir[i][0]][sj+dir[i][1]]='X';//设置志。变为不可通过,表明已经搜过
dfs(si+dir[i][0],sj+dir[i][1],cnt+1); //从此点开始递归
map[si+dir[i][0]][sj+dir[i][1]]='.'; //递归完,将该点还原
}
}
return;
} int main()
{
int i,j ; //循环变量
int si,sj; //小狗的起始位置
while (cin>>n>>m>>t)
{
if (n==0&&m==0&&t==0) break;//测试数据结束
int wall=0;
for (i=1;i<=n;i++)
for (j=1;j<=m;j++)
{
cin>>map[i][j];
if (map[i][j]=='S')
{
si=i; //记录起点位置
sj=j;
}
else if (map[i][j]=='D')
{
di=i; //记录门位置
dj=j;
}
else if (map[i][j]=='X') wall++; //wall 为不能穿越的方格的个数
}
if (n*m-wall<=t) //可以走的个数少于等于时间,说明即使全部走,也不能刚好在t时间到达门
{
cout<<"NO"<<endl;
continue;
}
escape=0; //逃跑成功标志位,成功了为1,不成功为0
map[si][sj]='X';
dfs(si,sj,0); //从起点出开始深搜,此时时间为零
if (escape) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
return 0;
}

  

DFS Zoj 2110的更多相关文章

  1. HDU 1010 Tempter of the Bone (ZOJ 2110) DFS+剪枝

    传送门: HDU:http://acm.hdu.edu.cn/showproblem.php?pid=1010 ZOJ:http://acm.zju.edu.cn/onlinejudge/showPr ...

  2. ZOJ 2110 Tempter of the Bone(DFS)

    点我看题目 题意 : 一个N×M的迷宫,D是门的位置,门会在第T秒开启,而开启时间小于1秒,问能否在T秒的时候到达门的位置,如果能输出YES,否则NO. 思路 :DFS一下就可以,不过要注意下一终止条 ...

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

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

  4. ZOJ 2110 DFS

    狗要出门,且正好在T秒 就是DFS + 剪枝, 联系一下剪枝技巧 #include<iostream> #include<cstdio> #include<cstring ...

  5. zoj 2110 Tempter of the Bone (dfs)

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

  6. zoj 2110 很好的dfs+奇偶剪枝

    //我刚开始竟然用bfs做,不断的wa,bfs是用来求最短路的而这道题是求固定时间的 //剪纸奇偶剪枝加dfs #include<stdio.h> #include<queue> ...

  7. DFS ZOJ 1002/HDOJ 1045 Fire Net

    题目传送门 /* 题意:在一个矩阵里放炮台,满足行列最多只有一个炮台,除非有墙(X)相隔,问最多能放多少个炮台 搜索(DFS):数据小,4 * 4可以用DFS,从(0,0)开始出发,往(n-1,n-1 ...

  8. stack+DFS ZOJ 1004 Anagrams by Stack

    题目传送门 /* stack 容器的应用: 要求字典序升序输出,所以先搜索入栈的 然后逐个判断是否满足答案,若不满足,回溯继续搜索,输出所有符合的结果 */ #include <cstdio&g ...

  9. 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 ...

随机推荐

  1. 强制关闭myeclipse出现的问题

    重启时,可能会出现打不开关闭前所在的workspace.其他workspace可以正常打开. 今天遇到这个问题,以前就遇到过,但是忘记如何解决了.今天在我等了十多分钟后,神奇的myeclipse自己起 ...

  2. WINDOWS批处理命令使用大全

    来源:http://www.942dn.com就是爱电脑网 WINDOWS批处理命令使用大全 批处理,也称为批处理脚本,英文译为BATCH,批处理文件后缀BAT就取的前三个字母.它的构成没有固定格式, ...

  3. 分布式发布订阅消息系统 Kafka 架构设计[转]

    分布式发布订阅消息系统 Kafka 架构设计 转自:http://www.oschina.net/translate/kafka-design 我们为什么要搭建该系统 Kafka是一个消息系统,原本开 ...

  4. Sqoop import加载HBase过程中,遇到Permission denied: user=root, access=WRITE, inode="/user":hdfs:supergroup:drwxr-xr-x

    在执行hbase sqoop抽取的时候,遇到了一个错误,如下图: 在执行程序的过程中,遇到权限问题很正常,也容易让人防不胜防,有问题就想办法解决,这个是关键. 解决办法如下: 第一步:su hdfs, ...

  5. nginx 要改进的地方基础

  6. Android输入法开发

    1. 概念 * IMF: 输入法框架(Input Method Framework) * IM: 输入法(Input Method) * IMS: 输入法服务(Input Method Service ...

  7. unix 环境高级编程 读书笔记与习题解答第四篇

    第一章 第六节 第一小节 这一章没有程序设计和API方面的深入学习,而是注重介绍了unix操作系统中的原始数据类型和系统原型函数,错误处理方面的知识. ____unistd.h____ 该文件包含了u ...

  8. 离散傅里叶变换(DFT)

    目录     一.研究的意义     二.DFT的定义    三.DFT与傅里叶变换和Z变换的关系     四.DFT的周期性     五.matlab实验       五.1 程序         ...

  9. 解决Maven中Missing artifact javax.jms:jms:jar:1.1:compile

    搭建好项目后报错: Missing artifact javax.jms:jms:jar:1.1:compile  于POM.xml中 解决方案: 一 :在nexus中配置一个代理仓库     地址为 ...

  10. KVO/KVC总结

    KVO/KVC总结       下面是根据网上文章的总结,方便查看. 在网上看别人的文章,了解KVC.KVO,有个kvo-kvc的例子,就是改变数组的内容(插入和删除),同步改变tableview中的 ...