Java项目实现寻找迷宫出路
作者:Sampson_S 发布时间:2022-10-05 14:08:46
标签:java,迷宫
本文实例为大家分享了Java实现寻找迷宫出路的具体代码,供大家参考,具体内容如下
项目名称
寻找迷宫出路
项目描述
给定一个自定义迷宫,0表示能通过,1表示不能通过。通过程序找出正确的迷宫出路,并将正确的路线改为2输出。
代码实现
测试类
public class Test {
public static void main(String[] args) {
Maze maze = new Maze();
maze.begin();
}
}
主类:实现主方法
public class Maze {
private MazeNode[][] mazeNodes;
private int row;
private int col;
private Stack<MazeNode> stack = new Stack<>();
private static Scanner scanner = new Scanner(System.in);
public Maze(){
System.out.println("请输入行列数");
row = scanner.nextInt();
col = scanner.nextInt();
mazeNodes = new MazeNode[row][col];
}
public void initValue(){
System.out.println("输入迷宫路径:");
for(int i=0;i<row;i++){
for(int j=0;j<col;j++){
// i j
mazeNodes[i][j] = new MazeNode(scanner.nextInt(),i,j);
}
}
}
//2. 根据当前节点的四个方向上面的value值
// 初始化当前节点的四个方向行走状态
public void initWayState(){
for(int i=0;i<row;i++){
for(int j=0;j<col;j++){
//i j
if(mazeNodes[i][j].getValue()==0){
//东 :看东边节点的值是0
if(j+1<col && mazeNodes[i][j+1].getValue() == 0){
// 将当前节点i j 的东边方向设置成可走状态
mazeNodes[i][j].setWayState(Constant.WAY_EAST,Constant.WAY_ABLE);
}
//西
if(j-1>0 && mazeNodes[i][j-1].getValue() == 0){
mazeNodes[i][j].setWayState(Constant.WAY_WEST,Constant.WAY_ABLE);
}
//南
if(i+1<row && mazeNodes[i+1][j].getValue() == 0){
mazeNodes[i][j].setWayState(Constant.WAY_SOUTH,Constant.WAY_ABLE);
}
//北
if(i-1>0 && mazeNodes[i-1][j].getValue() == 0){
mazeNodes[i][j].setWayState(Constant.WAY_NORTH,Constant.WAY_ABLE);
}
}
}
}
}
//走迷宫
public void goMaze(){
if(mazeNodes[0][0].getValue()!=0){
System.out.println("没有迷宫路径");
return;
}
stack.push(mazeNodes[0][0]);
while (!stack.isEmpty()) {//TODO:??????
MazeNode top = stack.peek();
//获取当前栈顶元素在二维数组中的行列坐标
int i = top.getI();
int j = top.getJ();
if(i == row-1 && j==col-1){
System.out.println("找到迷宫路径");
return;
}
//TODO:
if(mazeNodes[i][j].getWayState(Constant.WAY_SOUTH) == Constant.WAY_DISABLE &&
mazeNodes[i][j].getWayState(Constant.WAY_EAST) == Constant.WAY_DISABLE &&
mazeNodes[i][j].getWayState(Constant.WAY_NORTH) == Constant.WAY_DISABLE &&
mazeNodes[i][j].getWayState(Constant.WAY_WEST) == Constant.WAY_DISABLE){
stack.pop();
}
//东
else if (mazeNodes[i][j].getWayState(Constant.WAY_EAST)) {
stack.push(mazeNodes[i][j + 1]);
mazeNodes[i][j+1].setWayState(Constant.WAY_WEST,Constant.WAY_DISABLE);
mazeNodes[i][j].setWayState(Constant.WAY_EAST,Constant.WAY_DISABLE);
}//南
else if (mazeNodes[i][j].getWayState(Constant.WAY_SOUTH)) {
//如果南边方向可走,将南边节点进行入栈操作
stack.push(mazeNodes[i + 1][j]);
//封路1:将南边节点的回路(北边)方向封掉
mazeNodes[i+1][j].setWayState(Constant.WAY_NORTH,Constant.WAY_DISABLE);
//封路2:将当前节点i,j 走过的路封掉 TODO:
mazeNodes[i][j].setWayState(Constant.WAY_SOUTH,Constant.WAY_DISABLE);
}
//西
else if (mazeNodes[i][j].getWayState(Constant.WAY_WEST)) {
stack.push(mazeNodes[i][j - 1]);
mazeNodes[i][j-1].setWayState(Constant.WAY_EAST,Constant.WAY_DISABLE);
mazeNodes[i][j].setWayState(Constant.WAY_WEST,Constant.WAY_DISABLE);
}
//北
else if (mazeNodes[i][j].getWayState(Constant.WAY_NORTH)) {
stack.push(mazeNodes[i - 1][j]);
mazeNodes[i-1][j].setWayState(Constant.WAY_SOUTH,Constant.WAY_DISABLE);
mazeNodes[i][j].setWayState(Constant.WAY_NORTH,Constant.WAY_DISABLE);
}
// if(mazeNodes[i][j].getWayState(Constant.WAY_SOUTH) == Constant.WAY_DISABLE &&
// mazeNodes[i][j].getWayState(Constant.WAY_EAST) == Constant.WAY_DISABLE &&
// mazeNodes[i][j].getWayState(Constant.WAY_NORTH) == Constant.WAY_DISABLE &&
// mazeNodes[i][j].getWayState(Constant.WAY_WEST) == Constant.WAY_DISABLE){
// stack.pop();
// }
}
}
public void finish(){
while (!stack.isEmpty()) {
MazeNode top = stack.peek();
top.setValue(2);
stack.pop();
}
System.out.println("迷宫路径为:");
int i = 0, j = 0;
while (i<row){
for (j = 0; j < col; j++) {
System.out.print(mazeNodes[i][j].getValue()+" ");
}
System.out.println();
i++;
}
}
public void begin(){
initValue();
initWayState();
goMaze();
finish();
}
// public void show(){
// for(int i=0;i<row;i++){
// for(int j=0;j<colum;j++){
// System.out.print(mazeNodes[i][j].value+" ");
// }
// System.out.println();
// }
// }
}
MazeNode:结点类,用于迷宫结点
public class MazeNode {
private int i;
private int j;
private int value;
private boolean[] wayState;
public MazeNode(int value,int i,int j){
wayState = new boolean[Constant.WAYNUM];
this.value = value;
this.i = i;
this.j = j;
}
public int getValue() {
return value;
}
public void setWayState(int direction,boolean isAble) {
wayState[direction] = isAble;
}
public boolean getWayState(int direction) {
return wayState[direction];
}
public void setValue(int value){
this.value = value;
}
public int getI() {
return i;
}
public int getJ() {
return j;
}
}
Constant:常数类,方便使用
public class Constant {
public static final int WAYNUM = 4;
public static final int WAY_EAST = 0;
public static final int WAY_WEST = 1;
public static final int WAY_SOUTH = 2;
public static final int WAY_NORTH = 3;
public static final boolean WAY_ABLE = true;
public static final boolean WAY_DISABLE = false;
}
来源:https://blog.csdn.net/Sampson_S/article/details/105166802


猜你喜欢
- 按照常规思维,往一个map里put一个已经存在的key,会把原有的key对应的value值覆盖,然而通过一次线上问题,发现Java8中的Co
- 本文我们将要讨论Java面试中的各种不同类型的面试题,它们可以让雇主测试应聘者的Java和通用的面向对象编程的能力。下面的章节分为上下两篇,
- 一、利用距离感应器监听听筒靠近耳朵事件准确的说距离感应器并不能监听到你是否把手机靠近耳朵,也许是你用手挡在了距离感应器前面,但这不是我们关心
- 本文实例为大家分享了Java实现小型图书馆管理系统的具体代码,供大家参考,具体内容如下以下为小型图书馆管理系统模式图:模式总体概述:其中IB
- 两种情况setState() 能在 build() 中直接调用吗?答案是能也不能。来看一段简单的代码:import 'package
- 对单机服务做接口限流的处理方案简单说就是设定某个接口一定时间只接受固定次数的请求,比如/add接口1秒最多接收100次请求,多的直接拒绝,这
- 基于opencv的车道线检测,供大家参考,具体内容如下原理:算法基本思想说明:传统的车道线检测,多数是基于霍夫直线检测,其实这个里面有个很大
- @[toc]在之前的文章中松哥和小伙伴们聊过,正在执行的流程信息是保存在以 ACT_RU_ 为前缀的表中,执行完毕的流程
- FileOutPutStream:子类,写出数据的通道步骤:1.获取目标文件2.创建通道(如果原来没有目标文件,则会自动创建一个)3.写入数
- 游戏界面程序代码using System;using System.Collections.Generic;using System.Com
- Android开发环境有三种方式,分别是JDK+SDK+Eclipse+ADT、JDK+adt-bundle与JDK+Android Stu
- 目录图标准备BottomNavigationBar 简介构建项目页面结构简化入口代码复用最终实现的结果如上图所示,顶部共用一个导航栏,底部有
- Android RadioButton 图片位置与大小Java:rgGroup = (RadioGroup) findViewById(R.
- 以前一直使用Hibernate,基本上没用过Mybatis,工作中需要做映射关系,简单的了解下Mybatis的映射。两者相差不多都支持一对一
- 本文实例讲述了Android控件之TabHost用法。分享给大家供大家参考。具体如下:以下通过TabHost实现android选项卡。mai
- 场景日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的
- 高快省的排序算法有没有既不浪费空间又可以快一点的排序算法呢?那就是“快速排序”啦!光听这个名字是不是就觉得很高端呢。假设我们现在对“6 1
- 本文是利用C# 实现FTP客户端的小例子,主要实现上传,下载,删除等功能,以供学习分享使用。思路:通过读取FTP站点的目录信息,列出对应的文
- 前言volatile相关的知识其实自己一直都是有掌握的,能大概讲出一些知识,例如:它可以保证可见性;禁止指令重排。这两个特性张口就来,但要再
- package 移位运算;public class 移位运算 { public static void main(String[] args