转载声明:原文转自:http://www.cnblogs.com/xiezie/p/5568822.html

第一次遇到迷宫搜索,给我的感觉是十分惊喜的:搞懂这个的话,感觉自己又掌握了一项技能~

个人感觉,角色扮演类的游戏,起码都可以在迷宫搜索上找到影子。

奇偶剪枝这个算法感觉十分开阔的视野~这样去描述这个具体问题实在太形象生动了~

总而言之,十分有趣。

仔细的人会发现  每当设计到移动,我们必须想到上下左右,这也让我们看到这类算法的思路。

在学习迷宫搜索当中,我发现:这个搜索算法是先分析 找到结果时的情形,然后再将通路换为障碍,经过上下左右后,再换回通路。(这是递归写法该有的一种套路吗?才疏学浅,不敢妄言)

另外,迷宫搜索类的题目不仅涉及到 回溯法,还让人好奇迷宫生成的算法~

接下来,应该研究下 迷宫生成算法和迷宫搜索算法中提及的 深度、广度搜索!

不得不借鉴他人的成果:

下面是剪枝的简单理论,一看就懂:

把map看作

0 1 0 1 0 1
                             1 0 1 0 1 0
                             0 1 0 1 0 1
                             1 0 1 0 1 0
                             0 1 0 1 0 1

从 0->1 需要奇数步

从 0->0 需要偶数步

以下是JAVA实现代码:

import java.util.*;
import java.io.*; public class Main{ public static void main(String[] arg){
Scanner scan = new Scanner(new BufferedInputStream(System.in));
int n,m,t;
while((n=scan.nextInt())!=0&&(m=scan.nextInt())!=0&&(t=scan.nextInt())!=0){
ok = false;
int x = 0,y = 0;
int targetX = 0,targetY = 0;
char[][] map = new char[n][m];
for(int i = 0 ; i != n ; i ++ ){
String row = scan.next();
char[] c = row.toCharArray();
for(int j = 0 ; j != m ; j ++ ){
map[i][j]=c[j];
if(c[j]=='.'){
continue;
}
if(c[j]=='X'){
continue;
}
if(c[j]=='S'){
x = i;
y = j;
continue;
}
if(c[j]=='D'){
targetX = i;
targetY = j;
}
}
}
//剪枝
if((targetX+targetY)%2==(x+y)%2){//相同
if(t%2==1){
t=-1;
}
}else{
if(t%2==0){//相异
t=-1;
}
}
findPath(map,x,y,t,targetX,targetY);
if(t==-1){
System.out.println("NO");
continue;
}
if(ok){
System.out.println("YES");
}else{
System.out.println("NO");
}
}
scan.close();
} static boolean ok = false; static void findPath(char[][] map,int i , int j,int t,int targetX,int targetY){
if(ok||t==-1){
return;
}
if(t==0&&(map[i][j]=='D'||i==targetX&&j==targetY)){
ok = true;
return;
}
map[i][j] = 'X';
//上
if(j - 1!=-1&& map[i][j-1]!='X'){
findPath(map,i,j-1,t-1,targetX,targetY);
}
//下
if(j + 1!=map[0].length&&map[i][j + 1]!='X' ){
findPath(map,i,j+1,t-1,targetX,targetY);
}
//左
if(i - 1!=-1&&map[i-1][j]!='X'){
findPath(map,i-1,j,t-1,targetX,targetY);
}
//右
if(i + 1!=map.length&&map[i+1][j ]!='X' ){
findPath(map,i+1,j,t-1,targetX,targetY);
}
map[i][j] = '.';
} }

HDOJ-ACM1010(JAVA) 奇偶剪枝法 迷宫搜索的更多相关文章

  1. hdu 1010(迷宫搜索,奇偶剪枝)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1010 Tempter of the Bone Time Limit: 2000/1000 MS (Ja ...

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

  3. HDU 1010 (DFS搜索+奇偶剪枝)

    题目链接:  http://acm.hdu.edu.cn/showproblem.php?pid=1010 题目大意:给定起点和终点,问刚好在t步时能否到达终点. 解题思路: 4个剪枝. ①dep&g ...

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

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

  6. DFS中的奇偶剪枝(技巧)

    剪枝是什么,简单的说就是把不可行的一些情况剪掉,例如走迷宫时运用回溯法,遇到死胡同时回溯,造成程序运行时间长.剪枝的概念,其实就跟走迷宫避开死胡同差不多.若我们把搜索的过程看成是对一棵树的遍历,那么剪 ...

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

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

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

  9. hdoj1010 奇偶剪枝+DFS

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

随机推荐

  1. mirantis fuel puppet执行顺序 和 对整个项目代码的执行流程理解

    stage执行顺序 stage {'zero': } -> stage {'first': } -> stage {'openstack-custom-repo': } -> sta ...

  2. mvc框架下,怎样用cookie实现下次自动登录

    登录时有个下次自动登录的checkBox.点了它下次就可以自动登录了 具体流程我都晓得,就是细节的地方有些搞不定.我只要解决3个问题: (1)登录时如果点了checkbox,则在本机产生一个cooki ...

  3. 2016041601 - maven用途

    以前只是使用maven只是当成jar依赖管理工具,并没有想到它有多么厉害的功能.现在看书系统学习maven才发现它的强大之处.个人认为通过博客去学习掌握一门技术,这是很低层次的学习方法.学习金字塔,学 ...

  4. 关于javac编译时出现“非法字符:\65279”的解决方法

    一般用UE或记事本编辑过的UTF-8的文件头会加入BOM标识,该标识由3个char组成.在UTF-8的标准里该BOM标识是可有可无的,Sun 的javac 在编译带有BOM的UTF-8的格式的文件时会 ...

  5. Amazon Alexa 语音识别2 : 设置

    开发者建立的Skill的主要设置项目都在Skill的console内.需要填写的东西大致有以下几个: 1.Skill 名字.这个名字是用户用来唤醒你这个Skill的. 2.Intent Schema: ...

  6. IndexedDB 增删改查 简单的库

    <!DOCTYPE html> <html> <head> <title></title> <script src="Ind ...

  7. 西门子plc串口通讯方式

    西门子plc串口通讯的三种方式 时间:2015-10-25 14:31:55编辑:电工栏目:西门子plc 导读:西门子plc串口通讯的三种方式,分为RS485 串口通信.PPI 通信.MPI 通信,自 ...

  8. linux删除某类型文件的命令

    使用linux命令行,删除某目录下某类型的文件,如:删除.rar结尾的所有文件. 命令如下: find . -name "*.rar" -type f -print -exec r ...

  9. 20 个最棒的 jQuery Tab 插件

    jQuery Tab 常用来做网页上的选项设置界面和导航,本文向你推荐最棒的 20 个 jQuery Tab 插件.Enjoy !! 1. Slider Tabs SliderTabs 是一个可定制的 ...

  10. JS单击隐藏界面元素

    1. JS代码 <script type="text/javascript" language="javascript"> // function ...