Java小案例-(逃离迷宫)

一,迷宫需求描述:

1,用户输入迷宫图(限制方形):字母1位墙,0为通,e为出口,m为入口,*为已访问的位置,用外围1围住迷宫

2,运行轨迹右,左,下,上

3,判断该迷宫是否能从入口走到出口,并将搜索过程输出

二,迷宫实现:

1,迷宫元素类MazeCell:

package smalldemo.maze;

 class MazeCell {
public int x,y;
public MazeCell(){
}
public MazeCell(int x,int y){
this.x=x;
this.y=y;
}
public boolean equals(MazeCell cell){
return x==cell.x && y==cell.y;
}
}

2,迷宫搜索类MazeUtils:

package smalldemo.maze;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.util.Stack;
class MazeUtils {
private int rows,columns;
private MazeCell currentCell,exitCell=new MazeCell(),entryCell=new MazeCell();
private final char wall='1',passage='0',visited='*',entryMarker='m',exitMarker='e';
private char[][] stores;
private Stack<MazeCell> mazePath=new Stack<MazeCell>();
MazeUtils(){
int row=0,column=0; InputStreamReader in=new InputStreamReader(System.in);
BufferedReader buf=new BufferedReader(in);
Stack<String> mazeRows=new Stack<String>();
System.out.println("Enter a rectangular maze using the following"+
"characters\nm -entry\ne -exit\n1 - wall \n0 - passage\n"+"Enter one line at one time:" +
"end with Ctrl- D:");
try {
String str=buf.readLine();
while(str !=null) {
row += 1;
columns = str.length();
str = "1" + str + "1";
mazeRows.push(str);
if (str.indexOf(entryMarker) != -1) {
entryCell.x = row;
entryCell.y = str.indexOf(entryMarker);
}
if (str.indexOf(exitMarker) != -1) {
exitCell.x = row;
exitCell.y = str.indexOf(exitMarker);
}
str = buf.readLine(); }
} catch (IOException e) {
e.printStackTrace();
}
rows=row;
stores=new char[rows+2][];
stores[0]=new char[columns+2];
for(;!mazeRows.empty();row --){
stores[row]=mazeRows.pop().toCharArray();
}
stores[rows+1]=new char[columns+2];
for(int i=0;i<columns+2;i+=1){
stores[0][i]=wall;
stores[rows+1][i]=wall;
}
}
private void display(PrintStream out){
for(int row =0;row <rows +1;row+=1){
out.println(stores[row]);
}
out.println();
}
private void pushUnvisited(int row,int col){
if(stores[row][col] ==passage || stores[row][col] == exitMarker){
mazePath.push(new MazeCell(row,col));
}
}
public void exitMaze(PrintStream out){
currentCell=entryCell;
out.println();
while (!currentCell.equals(exitCell)){
int x=currentCell.x;
int y=currentCell.y;
display(System.out);
stores[x][y]=visited;
pushUnvisited(x-1,y);
pushUnvisited(x+1,y);
pushUnvisited(x,y-1);
pushUnvisited(x,y+1);
if(mazePath.isEmpty()){
display(out);
out.println("Failure");
return;
}
else{
currentCell=mazePath.pop();
}
}
display(out);
out.println("Success!");
}
public static void main(String[] args){
new MazeUtils().exitMaze(System.out);
}
}

3,结果是:

Enter a rectangular maze using the followingcharacters
m -entry
e -exit
1 - wall
0 - passage
Enter one line at one time:end with Ctrl- D:
1101
000e
00m1
^D 111111
111011
1000e1
100m11 111111
111011
1000e1
100*11 111111
111011
1000e1
10**11 111111
111011
1000e1
1***11 111111
111011
1*00e1
1***11 111111
111011
1**0e1
1***11 111111
111011
1***e1
1***11 Success! Process finished with exit code 0

Java小案例-(逃离迷宫)的更多相关文章

  1. Java小案例(行星移动)

    Java小案例 行星移动:参考:三百集 使用软件:idea2017,java 1,图片集:这里  (idea图片源放在target目录下,才能访问到),建议从小往上看... 2,定义MyFrame p ...

  2. 深度优先搜索(DFS),逃离迷宫

    [原创] 今天来说说深度优先搜索,深度优先是图论中的内容,大意是从某一点出发,沿着一个方向搜索下去,并伴随着有回退的特点,通常用来判断某一解是否存在,不用来寻找最优解:这里来看一个非常有意思的题目: ...

  3. hdu 4524 郑厂长系列故事——逃离迷宫 小水题

    郑厂长系列故事——逃离迷宫 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) To ...

  4. 《java入门第一季》之类小案例(模拟用户登录)

    首先是做一个用户登录的小案例.在此基础上加入其它逻辑. import java.util.Scanner; /* * 模拟登录,给三次机会,并提示还有几次.如果登录成功,就可以玩猜数字小游戏了. * ...

  5. Session与Cookie的原理以及使用小案例>从零开始学JAVA系列

    目录 Session与Cookie的原理以及使用小案例 Cookie和Session所解决的问题 Session与Cookie的原理 Cookie的原理 Cookie的失效时机 小提示 Session ...

  6. 《java入门第一季》之Character类小案例

    /*  * Character 类在对象中包装一个基本类型 char 的值  * 此外,该类提供了几种方法,以确定字符的类别小写字母,数字,等等,并将字符从大写转换成小写,反之亦然  * */ 下面通 ...

  7. hdu 1728:逃离迷宫(DFS,剪枝)

    逃离迷宫 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  8. 02SpringMvc_springmvc快速入门小案例(XML版本)

    这篇文章中,我们要写一个入门案例,去整体了解整个SpringMVC. 先给出整个项目的结构图:

  9. Java小例子(学习整理)-----学生管理系统-控制台版

    1.功能介绍: 首先,这个小案例没有使用数据库,用集合的形式暂时保存数据,做测试! 功能: 增加学生信息 删除学生信息 修改学生信息 查询学生信息:  按照学号(精确查询)  按照姓名(模糊查询) 打 ...

随机推荐

  1. svn服务器配置以及自动同步到web服务器

    感觉再不用svn就真的老了. 安装 yum install subversion 新建repo mkdir -p /opt/svn/myrepo svnadmin create /opt/svn/my ...

  2. 使用GitLab进行落地项目的管理,并且自动更新、重启、回滚

      Gitlab 清空项目历史commit,节省空间 http://blog.csdn.net/dounine/article/details/77840416?locationNum=6&f ...

  3. H264与AAC ES打包成MP4

    注意 设置图像的sps pps MP4AddH264SequenceParameterSet(file,video,sps,sizeof(sps)); MP4AddH264PictureParamet ...

  4. python怎么解压压缩的字符串数据

    范例1: gzip import StringIO import gzip compresseddata = gzip方式压缩的字符串(html) compressedstream = StringI ...

  5. 深度学习应用系列(三)| autokeras使用入门

    我们在构建自己的神经网络模型时,往往会基于预编译模型上进行迁移学习.但不同的训练数据.不同的场景下,各个模型表现不一,需要投入大量的精力进行调参,耗费相当多的时间才能得到自己满意的模型. 而谷歌近期推 ...

  6. 最短路&生成树&二分图匹配&费用流问题

    最短路 题意理解,建图 https://vjudge.net/problem/UVALive-4128 飞机票+行程建图 https://vjudge.net/problem/UVALive-3561 ...

  7. curator管理es索引

    安装curator------------------rpm --import https://packages.elastic.co/GPG-KEY-elasticsearch vi /etc/yu ...

  8. Grunt Gulp Browserify Webpack

    Grunt 是相比后面几个更早的项目,他依赖于各种插件的配置.这是一个很好的解决方案,但是请相信我,你不会想看到一个 300 行的 Gruntfile Gulp 提供了一个不一样的解决方案,而不是依赖 ...

  9. [BZOJ3529]数表

    假设$n\leq m$,我们先不考虑$\leq a$的限制 $\sum\limits_{i=1}^n\sum\limits_{j=1}^m\sigma((i,j))=\sum\limits_{T=1} ...

  10. 【推导】【暴力】Codeforces Round #432 (Div. 2, based on IndiaHacks Final Round 2017) C. Five Dimensional Points

    题意:给你五维空间内n个点,问你有多少个点不是坏点. 坏点定义:如果对于某个点A,存在点B,C,使得角BAC为锐角,那么A是坏点. 结论:如果n维空间内已经存在2*n+1个点,那么再往里面添加任意多个 ...