1

我在使用 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)); 是一个我不知道的工具,但是我仍然收到运行时错误。再次感谢您的回复,并再次感谢您的进一步回复:)。上面的代码已按建议修改,但运行时错误仍然存​​在

4

1 回答 1

1

您的代码有几个问题:

  • 您的嵌套循环假定数组是方形的(您将两个维度迭代到grid.length),
  • 在初始化每一行后打印整个数组,并且
  • 您错误地打印了数组(Java 数组在传递给 时不打印它们的内容System.out.println

如果您的矩阵确实总是正方形,则第一项是可以的。第二项很容易通过将输出移到第二个嵌套循环之外来修复。

第三项是最难的。编写一个静态方法来获取二维数组,并使用两个嵌套循环逐个元素地打印出来,这将是一个很好的练习。System.out.println(Arrays.deepToString(grid));如果您更愿意使用系统功能,也可以使用。

于 2012-06-30T00:43:12.723 回答