我正在创建一个通过迷宫并选择正确路径的程序。有多个楼层和房间。我能够读取文件并让程序通过迷宫,但问题是程序正在打印文件中每个房间的解决方案,它应该只打印正确的路径。我正在尝试创建一个循环,其中真实的房间可以退出到 ArrayList 中,并忽略除了入口之外没有出路的房间。以下是文件中房间的示例:
1 0 0 0 0 0 0 1
0 0 0 0 0 1 0 0
0 0 0 0 0 0 0 0
0 0 0 1 0 0 0 1
0 0 0 1 0 0 0 0
1 0 0 1 0 1 0 0
0 0 0 1 0 0 0 0
1 0 0 1 0 0 0 1
这是我的代码,我将我认为应该工作的方式放在底部的切换注释中:
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Scanner;
public class Maze {
static boolean [][][] maze;
static int dimensions;
static boolean theEnd = false;
static ArrayList<Integer> path = new ArrayList<Integer>();
public static void main(String[] args) throws IOException {
String fileName = "";
Scanner input = new Scanner(System.in);
System.out.print("What's the name of the file: ");
fileName = input.nextLine();
Scanner inputFile = new Scanner(new File(fileName + ".txt"));
String firstLine = inputFile.nextLine();
String [] pieces = firstLine.split(" ");
dimensions = pieces.length;
maze = new boolean[dimensions][dimensions][dimensions];
for(int floor = 0; floor < dimensions; floor++){
for(int row = 0; row < dimensions; row++){
for(int column = 0; column < dimensions; column++){
int place = Integer.parseInt(pieces[column]);
if(place == 1){
maze[floor][row][column] = true;
}
else{
maze[floor][row][column]= false;
}
//System.out.print(place);
}
//System.out.println();
String nextLine = inputFile.nextLine();
if(!nextLine.isEmpty()){
pieces = nextLine.split(" ");
}
else if (floor != dimensions - 1){
pieces = inputFile.nextLine().split(" ");
}
}
}
traverse(0,0,0);
inputFile.close();
input.close();
//System.out.println(theEnd);
}
private static void traverse(int floor, int row, int column) {
maze[floor][row][column]= false;
if(floor == dimensions - 1 && row == dimensions - 1 && column == dimensions - 1){
theEnd = true;
}
if(row != 0 && maze[floor][row - 1][column]){
traverse (floor, row - 1, column);
}
if(row != dimensions -1 && maze[floor][row + 1][column]){
traverse (floor, row + 1, column);
}
if(column != 0 && maze[floor][row][column - 1]){
traverse (floor, row, column - 1);
}
if(column != dimensions -1 && maze[floor][row][column + 1]){
traverse (floor, row, column + 1);
}
if(floor != 0 && maze[floor - 1][row][column]){
traverse (floor - 1, row, column);
}
if(floor != dimensions - 1 && maze[floor + 1][row][column]){
traverse (floor + 1, row, column);
}
do{
System.out.println("(" + floor + ", " + row + ", " + column + ")");
}while(maze.equals(true));
// if (the room is true and can be exited){
// then add the room to the ArrayList
//}
// else {
// the room should be skipped and not added to the ArrayList
//}
}
}
我将如何创建 if else 语句以将可以退出的房间添加到 ArrayList 中?谢谢你的帮助!