Java項(xiàng)目實(shí)現(xiàn)尋找迷宮出路
本文實(shí)例為大家分享了Java實(shí)現(xiàn)尋找迷宮出路的具體代碼,供大家參考,具體內(nèi)容如下
項(xiàng)目名稱
尋找迷宮出路
項(xiàng)目描述
給定一個(gè)自定義迷宮,0表示能通過(guò),1表示不能通過(guò)。通過(guò)程序找出正確的迷宮出路,并將正確的路線改為2輸出。

代碼實(shí)現(xiàn)
測(cè)試類
public class Test {
public static void main(String[] args) {
Maze maze = new Maze();
maze.begin();
}
}
主類:實(shí)現(xiàn)主方法
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("請(qǐng)輸入行列數(shù)");
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. 根據(jù)當(dāng)前節(jié)點(diǎn)的四個(gè)方向上面的value值
// 初始化當(dāng)前節(jié)點(diǎn)的四個(gè)方向行走狀態(tài)
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){
//東 :看東邊節(jié)點(diǎn)的值是0
if(j+1<col && mazeNodes[i][j+1].getValue() == 0){
// 將當(dāng)前節(jié)點(diǎn)i j 的東邊方向設(shè)置成可走狀態(tài)
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();
//獲取當(dāng)前棧頂元素在二維數(shù)組中的行列坐標(biāo)
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)) {
//如果南邊方向可走,將南邊節(jié)點(diǎn)進(jìn)行入棧操作
stack.push(mazeNodes[i + 1][j]);
//封路1:將南邊節(jié)點(diǎn)的回路(北邊)方向封掉
mazeNodes[i+1][j].setWayState(Constant.WAY_NORTH,Constant.WAY_DISABLE);
//封路2:將當(dāng)前節(jié)點(diǎn)i,j 走過(guò)的路封掉 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:結(jié)點(diǎn)類,用于迷宮結(jié)點(diǎn)
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:常數(shù)類,方便使用
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;
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java中對(duì)象快速?gòu)?fù)制的幾種方式詳解
這篇文章主要介紹了Java中對(duì)象快速?gòu)?fù)制的幾種方式詳解,對(duì)象的克隆是指創(chuàng)建一個(gè)新的對(duì)象,且新的對(duì)象的狀態(tài)與原始對(duì)象的狀態(tài)相同,當(dāng)對(duì)克隆的新對(duì)象進(jìn)行修改時(shí),不會(huì)影響原始對(duì)象的狀態(tài),需要的朋友可以參考下2023-08-08
談?wù)凧ava中對(duì)象,類和this,super,static關(guān)鍵字的使用
對(duì)象:對(duì)象是類的一個(gè)實(shí)例,有狀態(tài)和行為。類:類是一個(gè)模板,它描述一類對(duì)象的行為和狀態(tài)。本文就來(lái)和大家聊聊Java中對(duì)象,類和關(guān)鍵字的使用,需要的可以參考一下2022-08-08
SpringBoot中基于JWT的單token授權(quán)和續(xù)期方案步驟詳解
在前后端分離架構(gòu)中,用戶登錄后,后端生成JWT?Token返給前端存于LocalStorage,每次請(qǐng)求攜帶Token驗(yàn)證身份,后端校驗(yàn)其有效性,本文給大家介紹SpringBoot中基于JWT的單token授權(quán)和續(xù)期方案步驟詳解,感興趣的朋友一起看看吧2024-09-09
RocketMQ之Consumer整體介紹啟動(dòng)源碼分析
這篇文章主要為大家介紹了RocketMQ源碼分析之Consumer整體介紹啟動(dòng)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
Springmvc 4.x利用@ResponseBody返回Json數(shù)據(jù)的方法
這篇文章主要介紹了Springmvc 4.x利用@ResponseBody返回Json數(shù)據(jù)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
IntelliJ IDEA設(shè)置代碼的快捷編輯模板Live Templates
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA設(shè)置代碼的快捷編輯模板Live Templates,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-10-10
Java 實(shí)戰(zhàn)項(xiàng)目基于遺傳算法學(xué)校排課系統(tǒng)的實(shí)現(xiàn)流程
讀萬(wàn)卷書不如行萬(wàn)里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+Springboot+Maven+mybatis+Vue+Mysql實(shí)現(xiàn)一個(gè)基于遺傳算法的學(xué)校排課系統(tǒng),大家可以在過(guò)程中查缺補(bǔ)漏,提升水平2021-11-11
Java解決LocalDateTime傳輸前端為時(shí)間的數(shù)組
本文主要介紹了Java解決LocalDateTime傳輸前端為時(shí)間的數(shù)組,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-03-03

