首页 > 解决方案 > 修复数组的索引超出范围?

问题描述

我正在使用 Eclipse 控制台创建一个迷宫游戏。我正在尝试移动一名球员,并为球员保存新位置,以便我可以将他移动到另一个方向。但是,每次我尝试移动播放器时,我都会得到索引 ___ 超出长度 5(通常为 -1 或 5)的范围。它正在跳过整个数组,我不确定如何修复它。

运行时,它会打印以下内容

磷。. !.

. . . . .

. . . !.

!!. 吨。

!. !!.

请选择以下选项之一:

按 1 向上移动。

按 2 向下移动。

按 3 向左移动。

按 4 向右移动。

按 0 停止游戏。

我只列出了一个动作,但其余的都是一样的,有互换的变量。每个选项都返回索引超出范围。有人建议我创建一个“检查”系统,但这并不能解决问题。它只是运行程序而不允许任何动作,因为每个动作都会返回出界。我相信这与线路有关

mazeStructure[vxTemp][vyTemp] = mazeStructure[i][k-1];

无论是那个还是与 for 条件有关的东西。如果有人可以提供修复,将不胜感激。

Scanner input = new Scanner(System.in);
int rowsTotal = 5;
int columnsTotal = 5;
int vxTemp = 0;
int vyTemp = 0;
String[][] mazeStructure =  {
        {"P",".",".","!","."},
        {".",".",".",".","."},
        {".",".",".","!","."},
        {"!","!",".","T","."},
        {"!",".","!","!","."},
};

 boolean won = false;
while (won == false){
    for (int a = 0; a < rowsTotal; a++){
        for (int b = 0; b < columnsTotal; b++){
            System.out.print(mazeStructure[a][b]);
            System.out.print(" ");
    }
        System.out.print("\n");
  }


    System.out.printf("\n");
    System.out.println("Please select one of the following:");
    System.out.println("Press 1 to move up.");
    System.out.println("Press 2 to move down.");
    System.out.println("Press 3 to move left.");
    System.out.println("Press 4 to move right.");
    System.out.println("Press 0 to stop playing the game.");
    int choice = input.nextInt();
    int a = 0;

   
    if (choice == 1 && a >= 0 && a < columnsTotal){
    for (int i = 0; i < rowsTotal; i++){
        for (int k = 0; k < columnsTotal; k++){
        if (mazeStructure[vxTemp][vyTemp-1].equals("!") == false && mazeStructure[i][k].equals(mazeStructure[vxTemp][vyTemp])){
                    mazeStructure[vxTemp][vyTemp] = ".";
                    mazeStructure[vxTemp][vyTemp-1] = "P";
                    mazeStructure[vxTemp][vyTemp] = mazeStructure[i][k-1];
       }else if (mazeStructure[vxTemp][vyTemp-1] == "!"){
                    System.out.println("Move isn't allowed.");
       }else {
        continue;}

标签: javaarrays2dmaze

解决方案


if (mazeStructure[vxTemp][vyTemp-1].equals("!") == false && mazeStructure[i][k].equals(mazeStructure[vxTemp][vyTemp])){您尝试访问的行mazeStructure[vxTemp][vyTemp-1]。您在 0 处初始化vyTemp,并且在此之前它不会改变。您以尝试开始该循环,vyTemp - 1这将是-1。这将超出您的数组的范围。

k您对循环中的变量执行相同的操作。第一次k将是零。因此,尽管k - 1现有一切都可以,但您不能尝试访问某个 -1 索引处的任何数组。


推荐阅读