我在使用 2D 数组和插入需要 3 个参数(int x、int y、int cost)的对象时遇到了困难。这是搜索算法的开始,诚然,我的开始很糟糕。我将粘贴下面的代码。当我尝试运行此代码时收到编译错误,我很确定它很简单,但我无法解决它。我打算用来实现主要算法的 Map2 类,例如排序等。
import java.util.Arrays;
public class Map2 {
public static void main (String args[]){
Points[][] grid = new Points[4][4];
for(int i = 0; i < grid.length; i++){
for(int j = 0; j < grid.length; j++){
grid[i][j] = new Points(i,j,1);
}
}
System.out.print(Arrays.deepToString(grid));
}
}
这个类是我的对象,它包含从一个位置移动到下一个位置的移动成本(下一步显然是确定邻居),是的,这是尝试创建一个有效的 A 星算法的一部分。
public class Points {
int x;
int y;
int movement_cost;
public Points(int iX, int iY, int cost){
x = iX;
y = iY;
movement_cost = cost;
}
public int getX(){
return x;
}
public int getY(){
return y;
}
public int getMovementCost(){
return movement_cost;
}
public void setX(int x){
this.x = x;
}
public void setY(int y){
this.y = y;
}
public void setMovementCost(int cost){
this.movement_cost = cost;
}
public String toString(){
return ""+getX()+ ""+getY()+""+getMovementCost();
}
}
这是编译后读出的控制台(内存中有3个地址空间)
run:[[001, 011, 021, 031], [101, 111, 121, 131],
[201, 211, 221, 231], [301, 311, 321, 331]]
BUILD SUCCESSFUL (total time: 2 seconds)
我希望这里很简单,数组中的每个对象都将包含其在内存中的坐标的引用并包含移动成本,稍后将用于比较以确定下一个最佳位置(我稍后将实现诸如目标,开始)
我的问题是:代码有什么问题吗?
我要提前感谢任何回复的人,因为您的回复将永远受到赞赏
我的问题 V0.1 的当前修订:哇,非常感谢您的快速响应,我今天学到了一些新东西^^ Arrays.deepToString(grid)); 是一个我不知道的工具,但是我仍然收到运行时错误。再次感谢您的回复,并再次感谢您的进一步回复:)。上面的代码已按建议修改,但运行时错误仍然存在