目标:找到到达目的地所需的最少移动量。
场景:在 2D Array 8*8 中,包含以下元素:
*......B
........
****.**.
.A....*.
........
....**..
........
....*...
在哪里
- “A”代表起点。
- “B”代表目的地点。
- “*”表示障碍物。
- “.”代表一个空单元格。
目前我已经完成了以下代码:
import java.io.BufferedReader;
import java.io.DataInputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStreamReader;
class main
{
public static void main(String args[]) throws FileNotFoundException,IOException
{
FileInputStream FS = new FileInputStream("path.in");
DataInputStream DS = new DataInputStream(FS);
BufferedReader buffer = new BufferedReader(new InputStreamReader(DS));
String strLine = buffer.readLine();
int testCase = Integer.parseInt(strLine);
int R,C;
for(int i = 0;i < testCase;i++)
{
strLine = buffer.readLine();
String input[] = strLine.split(" ");
R = Integer.parseInt(input[0]);
C = Integer.parseInt(input[1]);
char[][] array = new char[R][C];
int sCoordX = 0;
int sCoordY = 0;
int eCoordX = 0;
int eCoordY = 0;
for(int j = 0; j < R ; j++)
{
strLine = buffer.readLine();
for(int k = 0;k < C;k++)
{
array[j][k] = strLine.charAt(k);
if(array[j][k] == 'A')
{
sCoordX = j;
sCoordY = k;
}
if(array[j][k] == 'B')
{
eCoordX = j;
eCoordY = k;
}
}
}
boolean reached = false;
int counter = 0;
int posX = sCoordX;
int posY = sCoordY;
while(!reached)
{
if(array[posX][posY] == 'B')
{
reached = true;
System.out.println("You are in goal!");
System.out.println(array[posX][posY]);
System.out.println("Number of steps:"+counter);
}
if(!reached && posX > eCoordX)
{
posX--;
counter++;
}
else if(!reached && posX < eCoordX)
{
posX++;
counter++;
}
if(!reached && posY > eCoordY)
{
posY--;
counter++;
}
else if(!reached && posY < eCoordY)
{
posY++;
counter++;
}
}
}
}
}
它的工作是找到到达目的地所需的“最短”步数,但是它将任何/障碍视为可以移动到的空单元。
我目前无法找到一种方法来对其进行编码,使其能够识别下一个动作的正确决定。
我正在考虑使用数组列表和一些算法,但是我尝试阅读一些算法,例如Dijkstra 的算法,但它看起来真的很混乱,有人可以帮助我以一种非常简单的方式理解它以在 java 中实现它吗?
//-(对不起我的编码技能,我还是个初学者)-