Java小案例-(逃离迷宫)
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小案例-(逃离迷宫)的更多相关文章
- Java小案例(行星移动)
Java小案例 行星移动:参考:三百集 使用软件:idea2017,java 1,图片集:这里 (idea图片源放在target目录下,才能访问到),建议从小往上看... 2,定义MyFrame p ...
- 深度优先搜索(DFS),逃离迷宫
[原创] 今天来说说深度优先搜索,深度优先是图论中的内容,大意是从某一点出发,沿着一个方向搜索下去,并伴随着有回退的特点,通常用来判断某一解是否存在,不用来寻找最优解:这里来看一个非常有意思的题目: ...
- hdu 4524 郑厂长系列故事——逃离迷宫 小水题
郑厂长系列故事——逃离迷宫 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) To ...
- 《java入门第一季》之类小案例(模拟用户登录)
首先是做一个用户登录的小案例.在此基础上加入其它逻辑. import java.util.Scanner; /* * 模拟登录,给三次机会,并提示还有几次.如果登录成功,就可以玩猜数字小游戏了. * ...
- Session与Cookie的原理以及使用小案例>从零开始学JAVA系列
目录 Session与Cookie的原理以及使用小案例 Cookie和Session所解决的问题 Session与Cookie的原理 Cookie的原理 Cookie的失效时机 小提示 Session ...
- 《java入门第一季》之Character类小案例
/* * Character 类在对象中包装一个基本类型 char 的值 * 此外,该类提供了几种方法,以确定字符的类别小写字母,数字,等等,并将字符从大写转换成小写,反之亦然 * */ 下面通 ...
- hdu 1728:逃离迷宫(DFS,剪枝)
逃离迷宫 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- 02SpringMvc_springmvc快速入门小案例(XML版本)
这篇文章中,我们要写一个入门案例,去整体了解整个SpringMVC. 先给出整个项目的结构图:
- Java小例子(学习整理)-----学生管理系统-控制台版
1.功能介绍: 首先,这个小案例没有使用数据库,用集合的形式暂时保存数据,做测试! 功能: 增加学生信息 删除学生信息 修改学生信息 查询学生信息: 按照学号(精确查询) 按照姓名(模糊查询) 打 ...
随机推荐
- Android Studio2.3相关文章
安卓之旅第一站--第一次Android Studio2.3搭建过程总结 http://blog.csdn.net/iam549032340/article/details/56838907 Andro ...
- 玩转树莓派 - 修改Raspbian软件源加快软件下载速度
这是 meelo 原创的 玩转树莓派 系列文章 步骤1:登录到Raspbian的命令行界面 步骤2:修改Raspbian的软件源 软件源是Linux系统免费的应用程序安装仓库,很多的应用软件都会这收录 ...
- Linux下使用ssh远程登录服务器
如果自己的服务器是在内网,想在外网通过ssh在自己的VPS服务器上远程登录自己的内网服务器,可以按照如下操作: 一.在自己的服务器上使用如下命令: #ssh -CfnNT -R 端口A:localho ...
- Partial Views
@Html.Partial("MyPartial") @Html.Partial("MyStronglyTypedPartial", new [] {&qu ...
- 01 java 基础:jdk jre path classpath 相关问题
JRE : Java 运行环境 JDK : Java 开发工具包,其中包括 JRE (javac.java.javap.jar.javadoc .javah 等命令) JVM : Java 虚拟机 ...
- oracle导入DMP步骤
oracle导入DMP步骤如下:1.已经存在的数据库需要进行以下的操作,如果不存在,可略过: 删除用户 drop user SUDMDB cascade; 删除表空间和数据文件 ...
- nginx静态资源浏览器缓存
1.缓存介绍 作用:提升用户体验,减少服务器压力 浏览器无缓存:浏览器发起请求->无缓存->请求WEB服务器->web服务器检查是否有更新(没有更新返回304)->呈现 浏览器 ...
- 2017CCPC 杭州 J. Master of GCD【差分标记/线段树/GCD】
给你一个n个初始元素都为1的序列和m个询问q. 询问格式为:l r x(x为2or3) 最后求1~n所有数的GCD GCD:把每个数分别分解质因数,再把各数中的全部公有质因数提取出来连乘,所得的积就是 ...
- 洛谷P1392 取数 [堆]
题目传送门 取数 题目描述 在一个n行m列的数阵中,你须在每一行取一个数(共n个数),并将它们相加得到一个和.对于给定的数阵,请你输出和前k小的取数方法. 输入输出格式 输入格式: 第一行,三个数n, ...
- Git常用命令速查手册
Git组成 1.初始化仓库 git init 2.将文件添加到仓库 git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文 ...