HDU1010(bfs)
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <stdlib.h>
using namespace std;
int n,m,t,ax,bx;
bool flag;
char plot[9][9];
int dir[4][2]={{0,1},{1,0},{0,-1},{-1,0}};
void dfs(int a,int b,int tx){
if(a<=0||a>n||b<=0||b>m){
return;}
if(a==ax&&b==b&&tx==t){
flag=1;
return;}
int temp=(t-tx)-abs(a-ax)-abs(b-bx);
if(temp<0||temp&1){
return;}
for(int i=0;i<4;i++){
if(plot[a+dir[i][0]][b+dir[i][1]]!='X'){
plot[a+dir[i][0]][b+dir[i][1]]='X';
dfs(a+dir[i][0],b+dir[i][1],tx+1);
if(flag)
{
return;
}
plot[a+dir[i][0]][b+dir[i][1]] ='.';
}
}
return;
}
int main(){
while(scanf("%d%d%d",&n,&m,&t),n,m,t){
getchar();
int si,sj;
int ss=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
scanf("%c",&plot[i][j]);
if(plot[i][j]=='S'){si=i;sj=j;}
if(plot[i][j]=='D'){ax=i;bx=j;}
if(plot[i][j]=='X')ss++;
}
getchar();
}
if(n*m-ss<=t){
printf("NO\n");
continue;
}
flag=0;
plot[si][sj]='X';
dfs(si,sj,0);
if(flag)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}
这里需要剪枝,我参考了一下大牛的解说;
http://acm.hdu.edu.cn/forum/read.php?tid=6158
下面是用javaA过了的
import java.util.Scanner;
public class HDU1010{
static int n,m,t,ax,bx,si,sj;
static char[][]plot;
static boolean flag;
static int dir[][]={{1,0},{0,1},{0,-1},{-1,0}};
public static void main(String args[]){
Scanner cin=new Scanner(System.in);
while(cin.hasNext()){
n=cin.nextInt();
m=cin.nextInt();
t=cin.nextInt();
if(n==0&&m==0&&t==0)
break;
String str[]=new String [n+1];
for(int i=1;i<=n;i++){
str[i]=cin.next();
}
int ss=0;
plot=new char[9][9];
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
plot[i][j]=str[i].charAt(j-1);
if(plot[i][j]=='S'){
si=i;sj=j;
}
if(plot[i][j]=='X'){
ss++;
}
if(plot[i][j]=='D'){
ax=i;
bx=j;
}
}
}
if(n*m-ss<=t){
System.out.println("NO");
continue;
}
flag=false;
plot[si][sj]='X';
dfs(si,sj,0);
if(flag){
System.out.println("YES");
}
else{
System.out.println("NO");
}
}
return;
}
private static void dfs(int si, int sj, int i) {
if(si<=0||si>n||sj<=0||sj>m){
return;
}
if(si==ax&&sj==bx&&i==t){
flag=true;
return;
}
int temp=(t-i)-Math.abs(si-ax)-Math.abs(sj-bx);
if(temp<0||temp%2==1){
return;
}
for(int j=0;j<4;j++){
if(plot[si+dir[j][0]][sj+dir[j][1]]!='X'){
plot[si+dir[j][0]][sj+dir[j][1]]='X';
dfs(si+dir[j][0],sj+dir[j][1],i+1);
if(flag)
return;
plot[si+dir[j][0]][sj+dir[j][1]]='.';
}
}
return;
}
}
HDU1010(bfs)的更多相关文章
- HDU 1242 -Rescue (双向BFS)&&( BFS+优先队列)
题目链接:Rescue 进度落下的太多了,哎╮(╯▽╰)╭,渣渣我总是埋怨进度比别人慢...为什么不试着改变一下捏.... 開始以为是水题,想敲一下练手的,后来发现并非一个简单的搜索题,BFS做肯定出 ...
- 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)
图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...
- 【BZOJ-1656】The Grove 树木 BFS + 射线法
1656: [Usaco2006 Jan] The Grove 树木 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 186 Solved: 118[Su ...
- POJ 3278 Catch That Cow(bfs)
传送门 Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 80273 Accepted: 25 ...
- POJ 2251 Dungeon Master(3D迷宫 bfs)
传送门 Dungeon Master Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 28416 Accepted: 11 ...
- Sicily 1215: 脱离地牢(BFS)
这道题按照题意直接BFS即可,主要要注意题意中的相遇是指两种情况:一种是同时到达同一格子,另一种是在移动时相遇,如Paris在(1,2),而Helen在(1,2),若下一步Paris到达(1,1),而 ...
- Sicily 1048: Inverso(BFS)
题意是给出一个3*3的黑白网格,每点击其中一格就会使某些格子的颜色发生转变,求达到目标状态网格的操作.可用BFS搜索解答,用vector储存每次的操作 #include<bits/stdc++. ...
- Sicily 1444: Prime Path(BFS)
题意为给出两个四位素数A.B,每次只能对A的某一位数字进行修改,使它成为另一个四位的素数,问最少经过多少操作,能使A变到B.可以直接进行BFS搜索 #include<bits/stdc++.h& ...
- Sicily 1051: 魔板(BFS+排重)
相对1150题来说,这道题的N可能超过10,所以需要进行排重,即相同状态的魔板不要重复压倒队列里,这里我用map储存操作过的状态,也可以用康托编码来储存状态,这样时间缩短为0.03秒.关于康托展开可以 ...
随机推荐
- hbase安装(zookeeper等)
文库:http://wenku.baidu.com/link?url=5mnYL7ZuxUBWZnrnmak4JRVF5fJquJmjgmZy788i7UW8lUk4QXD8Nc_haPz33vjt9 ...
- Layout Resource官方教程(2)用ViewStub引用的嵌入的layout可推迟加载
Loading Views On Demand THIS LESSON TEACHES YOU TO Define a ViewStub Load the ViewStub Layout YOU SH ...
- 【HDOJ】4516 威威猫系列故事——因式分解
可解的算法太多了,采用的算法是试x的值.注意题目的输入x^3-2x^2不会写成x^3+-2x^2.一直RE在这儿. /* 4516 */ #include <iostream> #incl ...
- 转自 z55250825 的几篇关于FFT的博文(二)
题目大意:高精度乘法. fft的实现貌似有很多种,咱先写的是一种递归的fft,应该算是比较快的了吧.参考了 Evil君 的代码,那个运算符重载看的咱P党泪流满面. (没想到P竟然有运算符重载咩 ...
- 【转】VS2010/MFC编程入门之八(对话框:创建对话框类和添加控件变量)
原文网址:http://www.jizhuomi.com/software/153.html 前两讲中鸡啄米为大家讲解了如何创建对话框资源.创建好对话框资源后要做的就是生成对话框类了.鸡啄米再声明下, ...
- Git分支管理的基本操作
首先从远端版本库clone下来一个全新的库: git clone username@xxx:/xxx/xxx.git 此时clone下来的,只是master分支,没有其他分支. 查看分支: git b ...
- IT小说
最近迷上了IT小说,连着读了好几个连载.伴随着一个项目的一些事,一些矛盾,也能体现出一个社会的缩影.最吸引的应该是一种熟悉感,常常想要是拍成电视剧也应该很好看,像<半泽植树>似的.看完了, ...
- 微软的无限存储空间-OneDrive
10 月 28 日消息,微软今天宣布为所有 Office 365 的用户提供无上限的云存储服务,也就是 OneDrive 存储空间将从目前的 1TB 变成无上限,而且无需支付额外费用.这意味着曾经困扰 ...
- HW4.8
import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner i ...
- HDU-4115 Eliminate the Conflict 2sat
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4115 题意:Alice和Bob玩猜拳游戏,Alice知道Bob每次会出什么,为了游戏公平,Bob对Al ...