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.功能介绍: 首先,这个小案例没有使用数据库,用集合的形式暂时保存数据,做测试! 功能: 增加学生信息 删除学生信息 修改学生信息 查询学生信息: 按照学号(精确查询) 按照姓名(模糊查询) 打 ...
随机推荐
- bootstrap3中container与container_fluid容器的区别
声明:转自 CSDN博客 .container与.container_fluid是bootstrap中的两种不同类型的外层容器,按照官方的说法,这两者的区别是: .container 类用于固定宽度并 ...
- SGU 261. Discrete Roots
给定\(p, k, A\),满足\(k, p\)是质数,求 \[x^k \equiv A \mod p\] 不会... upd:3:29 两边取指标,是求 \[k\text{ind}_x\equiv ...
- bzoj 3295 CDQ求动态逆序对
#include<bits/stdc++.h> #define LL long long #define fi first #define se second #define mk mak ...
- ngCordova安装配置使用教程
ngCordova是什么 ngCordova是在Cordova Api基础上封装的一系列开源的AngularJs服务和扩展,让开发者可以方便的在HybridApp开发中调用设备能力,即可以在Angul ...
- LOJ #6282. 数列分块入门 6-分块(单点插入、单点查询、数据随机生成)
#6282. 数列分块入门 6 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 1 题目描述 给出 ...
- 《深入理解Android2》读书笔记(一)
2017-5-12 从今天开始估计有一段空闲时间,开始阅读<深入理解Android2>,并写读书笔记. 第一章搭建环境直接略过. 第二章是Binder,暂时略过 7大类服务包括:1.And ...
- Windows 下使用 mingw+msys 交叉编译 Android Unity Mono
对于没有升级到 Unity5.4的用户,发布安卓版本都会有对 C# 脚本进行加密的需求,我们项目在裸奔了很长时间后,决定开始做这件事. 网上查看了很多资料,我很希望直接在 windows 下编译而不去 ...
- 【tomcat】tomcat远程调试
修改tomcat bin目录下的catalina.sh,增加下面这行: CATALINA_OPTS="-agentlib:jdwp=transport=dt_socket,address=9 ...
- 安装xampp之后如何建立远程登录用户并修改登录方式和密码
其实xampp作为开发环是非常好用的,但是很少人将其用作生产环境,主要还是它的安全性较低,很多默认设置都存在安全漏洞,但是实际上使用xampp在Linux下面进行配置确实是很节省时间的一件事(如果你的 ...
- (hdu1007)Quoit Design,求最近点对
Problem Description Have you ever played quoit in a playground? Quoit is a game in which flat rings ...