HDOJ-ACM1010(JAVA) 奇偶剪枝法 迷宫搜索
转载声明:原文转自: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) 奇偶剪枝法 迷宫搜索的更多相关文章
- hdu 1010(迷宫搜索,奇偶剪枝)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1010 Tempter of the Bone Time Limit: 2000/1000 MS (Ja ...
- 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 ...
- HDU 1010 (DFS搜索+奇偶剪枝)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1010 题目大意:给定起点和终点,问刚好在t步时能否到达终点. 解题思路: 4个剪枝. ①dep&g ...
- 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 ...
- 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 ...
- DFS中的奇偶剪枝(技巧)
剪枝是什么,简单的说就是把不可行的一些情况剪掉,例如走迷宫时运用回溯法,遇到死胡同时回溯,造成程序运行时间长.剪枝的概念,其实就跟走迷宫避开死胡同差不多.若我们把搜索的过程看成是对一棵树的遍历,那么剪 ...
- 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 ...
- Tempter of the Bone(dfs奇偶剪枝)
Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- hdoj1010 奇偶剪枝+DFS
Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
随机推荐
- HIVE中内连接和左半连接不一致问题
一.理论 HIVE中都是按等值连接来统计的,理论上两种写法统计结果应该是一致的: 二.实际情况 但实际使用中发现两种写法会返回的结果,总会有一些差距虽然差别不大,但让人很是困惑. 三.原因 当使用jo ...
- 开发软件设计模型 visual studio UML
http://www.ibm.com/developerworks/cn/rational/rationaledge/content/feb05/bell/ http://msdn.microsoft ...
- C# 操作mongodb 分组
c#操作mongodb的分组的简单例子: 1.首先要下载c#对应的mongodb驱动,官方下载地址:https://github.com/mongodb/mongo-csharp-driver/rel ...
- input标签文字点击变颜色
<input type="text" class="ser_input"value="从这里搜索(^_^)" onfocus=&quo ...
- HDOJ多校联合第五场
1001 Inversion 题意:求逆序对,然后交换k次相邻的两个数,使得剩下的逆序对最少. 分析:题目用到的结论是:数组中存在一对逆序对,那么可以通过交换相邻两个数使得逆序对减少1,交换k次,可以 ...
- altium6.x中自动删除重复走线的位置
在protel 2004 DXP中,“自动删除走线”的位置就在"PCB Editor"的默认页面,非常好找. 但是升级到了altium 6.7,6.9之后,很多人就找不到这个了. ...
- 【原创】MIPS中断系统的板级验证及实例测试
“五一”假期前后这约五天时间,终于将MIPS中断系统进行了板级验证及实例测试.因为老师给的交叉编译工具不会用,所以测试代码完全用MIPS汇编编写.使用MARS而没有用QtSpim,其实我觉得SPIM这 ...
- tlplayer for ios V1.1(附上截图)
此程序UI修改于虎跃在线课堂.所以极其相似. 可以播放网络视频与本地视频,不知道怎么拷贝本地视频到Ipad或iphone上看的朋友,请自己到网上看教程. 支持mms,file,rtsp,rtmp,ht ...
- JSP个人总结
应用JSP技术开发动态网站 JSP基本语法 默认JSP: <%@ page language="java" contentType="text/html; char ...
- 2016年中国500强利润率最高的公司,中国500强最赚钱的40家公司,ROE最高的公司
2016年中国500强利润率最高的公司 排名 公司名称 利润率 62 阿里巴巴集团控股有限公司 73.09% 87 百度股份有限公司 50.71% 195 国信证券股份有限公司 47.87% ...