- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于这个作业,我将读取一个 .txt 文件并递归地导航它产生的迷宫(我将在下面提供一个示例)导航并打印它。我已经放下了导航,我的伙伴正在制作打印方法。但是,我在确定迷宫的起始位置时遇到问题。在迷宫中,起点用 s 表示。用图片更容易解释,所以我现在提供
5
#####
#s.##
##..#
###.#
#g..#
顶部的数字决定了数组的大小(我们必须将它们设为正方形)。 “#”是一堵墙,“.”是一堵墙。是可用路径,“g”是目标。现在我的问题是找到 s 的坐标,以便我知道从哪里开始迷宫。下面将是文件选择器类(问题所在)和导航迷宫的类(它可以工作,但我想我会包含它,以防有人好奇
public static void main(String[] args)
throws FileNotFoundException, IOException
{
FileReader myReader;
JFileChooser chooser = new JFileChooser();
if(chooser.showOpenDialog(null) == JFileChooser.APPROVE_OPTION)
{
File myFile = chooser.getSelectedFile();
myReader = new FileReader(myFile);
Scanner myScanner = new Scanner(myReader);
String placeHolder = myScanner.nextLine();
int arrayThings = Integer.parseInt(placeHolder);
char[][] maze = new char[arrayThings][arrayThings];
int rows = 0;
int collumns = 0;
for(int i = 0; i < maze.length(); i++)
{
if (maze[rows][collumns] == 's' || maze[rows][collumns] =='S')
{
FindPath(maze[arrayThings][arrayThings],rows,collumns);
}
}
myReader.close();
}
}
我不完全确定如何在迷宫中找到“s”。现在这是 FindPath 方法
public static boolean FindPath(char[][] maze,int x,int y)
{
try
{
if (maze[x][y] == 'g' || maze[x][y] =='G')
{
System.out.println("The maze was printed"); //Replace with print method
return true;
}
else if (maze[x][y] == '#' || maze[x][y] == '?' || maze[x][y] == 'P')
return false;
else
{
maze[x][y] = 'P';
System.out.println("The maze was printed"); //Replace with print method
if(MazeSolver.FindPath(maze,x,y-1)== true)
return true;
else if(MazeSolver.FindPath(maze,x+1,y)== true)
return true;
else if(MazeSolver.FindPath(maze,x,y+1)== true)
return true;
else if(MazeSolver.FindPath(maze,x-1,y)== true)
return true;
maze[x][y] = '?';
return false;
}
}
catch (ArrayIndexOutOfBoundsException myEx)
{
return false;
}
}
最佳答案
有两件事需要注意:
第一
下面的代码在二维数组被填充后,在二维数组中搜索字符s
。
for(int row = 0; row < maze.length; row++)
{
for(int col = 0; col < maze[0].length;col++){
if(maze[row][col] == 's'){
System.out.println("x :" + row + " y : " + col);
}
}
}
为什么在填充二维数组时不查找并跟踪字符s
?这将使您不必再次迭代二维数组。
row = 0;
maze = new char[arraySize][arraySize];
while(input.hasNextLine()) {
String lineHolder = input.nextLine();
// get the char array from the String
maze[row] = lineHolder.toCharArray();
if(lineHolder.indexOf('s') != -1) {
// start row equals the current row
sRow = row;
// start column equals the index/column of 's'
sCol = lineHolder.indexOf('s');
}
row = row + 1;
}
第二
无需使用 try catch block 来连接递归,只需实现边界检查即可。
// maze bounds checking, recursion no longer hinges on an exception
// being thrown
if(y < 0 || x < 0 || y > maze.length-1 || x > maze[0].length-1) {
return false;
}
<小时/>
我添加了以下工作代码来为上面提供的信息提供上下文。
public static void main(String[] args) {
JFileChooser chooser = null;
Scanner input = null;
int arraySize = 0;
char[][] maze;
int row = 0;
int sRow = 0;
int sCol = 0;
chooser = new JFileChooser();
if (chooser.showOpenDialog(null) == JFileChooser.APPROVE_OPTION) {
try {
input = new Scanner(chooser.getSelectedFile());
} catch(Exception e) {
System.out.println(e.getLocalizedMessage());
}
} else {
System.out.println("Exiting...");
System.exit(0);
}
if(input.hasNextLine()) {
arraySize = Integer.parseInt(input.nextLine().trim());
}
row = 0;
maze = new char[arraySize][arraySize];
while(input.hasNextLine()) {
String lineHolder = input.nextLine();
// get the char array from the String
maze[row] = lineHolder.toCharArray();
if(lineHolder.indexOf('s') != -1) {
// start row equals the current row
sRow = row;
// start column equals the index/column of 's'
sCol = lineHolder.indexOf('s');
}
row = row + 1;
}
input.close();
System.out.println("The maze has been read in:");
printMaze(maze);
FindPath(maze, sCol, sRow);
}
public static boolean FindPath(char[][] maze, int x, int y) {
// maze bounds checking, recursion no longer hinges on an exception
// being thrown
if(y < 0 || x < 0 || y > maze.length-1 || x > maze[0].length-1) {
return false;
}
if (Character.toLowerCase(maze[x][y]) == 'g') {
System.out.println("The maze has been solved:");
maze[x][y] = 'P';
printMaze(maze);
return true;
}
if(maze[x][y] == '.' || maze[x][y] == 's') {
maze[x][y] = 'P';
System.out.println("Solving...");
printMaze(maze);
if (FindPath(maze, x, y - 1)) {
return true;
} else if (FindPath(maze, x + 1, y)) {
return true;
} else if (FindPath(maze, x, y + 1)) {
return true;
} else if (FindPath(maze, x - 1, y)) {
return true;
}
return true;
} else {
// if maze[x][y] equals # or P then return false
return false;
}
}
public static void printMaze(char[][] maze) {
for(int r = 0; r < maze.length; r++) {
for(int c = 0; c < maze[r].length; c++) {
System.out.print(maze[r][c]);
}
System.out.print("\n");
}
}
The maze has been read in:######s.####..####.##g..#Solving...######P.####..####.##g..#Solving...######PP####..####.##g..#Solving...######PP####P.####.##g..#Solving...######PP####PP####.##g..#Solving...######PP####PP####P##g..#Solving...######PP####PP####P##g.P#Solving...######PP####PP####P##gPP#The maze has been solved:######PP####PP####P##PPP#
关于java - 使用二维数组导航 .txt 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29378475/
我知道我要求太多,但也许你也可以帮助解决这个问题。 a.txt 包含单词,b.txt 包含字符串。 我想知道 b.txt 中有多少个字符串以 a.txt 中的单词结尾 例子:一个.txt apple
这个问题在这里已经有了答案: erge text files ordered by numerical filenames in Bash (3 个答案) 关闭 4 年前。 我有一个文件夹,其中包含
我在一个目录中有几个平面文件 (.txt)。所有这些文件的格式都是 *.txt.txt,所以我想将其重命名为 *.txt?有什么简单的方法可以一起重命名? 当我尝试 ren *.txt.txt *.t
这个问题在这里已经有了答案: How can I use a file in a command and redirect output to the same file without trunc
您是否有任何理由应该或不应该允许访问 javascript 或 css 文件?特别是常见的文件,如 jquery。 最佳答案 人们普遍认为,搜索引擎每天为给定站点分配一定数量的带宽或 URL。因此,一
Closed. This question is off-topic。它当前不接受答案。 想要改善这个问题吗? Update the question,所以它是用于堆栈溢出的on-topic。 已关闭
这是相同的代码。我面临的问题是,我无法在任何文件上写入任何内容。请帮忙解决这个问题 #include #include int main() { FILE *fe; FILE *fo;
我想要特定于域的 robots.txt,到目前为止这有效: RewriteRule ^robots\.txt$ robots/%{HTTP_HOST}.txt [L] 但我希望有一个后备方案,因此如果
我正在调试一些构建成功运行的 SQL 命令的代码。 然而,在查询结束时,查询结果似乎被写入了一个文本文件。 完整的查询如下 echo SELECT DATE,DATETABLE,DATE,APPDAT
这个问题已经有答案了: difference between grep Vs cat and grep (5 个回答) 已关闭 8 年前。 我看到一个例子,其中有人这样做: cat source.tx
我想将表中的数据从以 csv 格式存储的文本文件插入到 sql server 表中。为此,我正在使用批量插入语句。现在我需要在“From”子句中指定文件名。我不想在那里使用网络位置或本地位置。我想将我
假设我有一个测试文件夹 (test.domain.com) 并且我不希望搜索引擎在其中抓取,我是否需要在测试文件夹中有一个 robots.txt 或者我可以只放置一个 robots.txt在根目录中,
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
这个问题在这里已经有了答案: order of directives in robots.txt, do they overwrite each other or complement each ot
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 8年前关闭。 Improve this
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
在过去的几年中,当我引用“名字”字段的文本框控件时,我一直使用 FirstNameTxt 命名约定。但是,我注意到大多数其他开发人员倾向于使用命名约定 txtFirstName 哪个是最好的约定?为什
我只想允许目录 /minsc 中的一个文件,但我想禁止该目录的其余部分。 现在 robots.txt 中是这样的: User-agent: * Crawl-delay: 10 # Directorie
我正在编写一个将 youtube.com 映射到另一个域的代理服务器(因此用户可以轻松地从德国等国家/地区访问 youtube,而无需审查搜索结果和视频)。 不幸的是,我的 robots.txt 中存
我没有编程技能,但有一项非常具体的任务:我必须将一个庞大的文本文件拆分成多个,并在特定的文本标记 (@) 处拆分它们。我决定尝试使用 Powershell 脚本来完成此任务。 到目前为止,这就是我想出
我是一名优秀的程序员,十分优秀!