繁体   English   中英

应用重力:2D数组

[英]Applying Gravity : 2D arrays

我的程序由2D数组组成的网格组成。 用户输入将删除网格的某些元素,并保留空白。 我的问题是使空格上方的元素下降。

最初,我有一个数组来检查空格是否为空白,如果为空白,则上面的元素将被删除并在以前为空白的地方重新创建。

我的问题是,我用来执行此操作的数组是Left-> Right,Top-> Down(i ++,j ++),这给我留下了必须重复整个代码才能获得新生成的空格的问题。 (例如,如果我从第三行中删除了某些内容,那么第二行将为空白,但是我已经检查了第二行。

由于这将是非常无效的(包括堆栈错误),因此我决定进行保留,底部->顶部,右侧->左侧数组(i-,j--),所以我遇到的问题是要获取数组超出范围错误,即使我确保它不可能超出范围也是如此。

这是一段有问题的代码

public static void dropBall(){
 for (i =Settings.row-1;i>=0;i--){
  for (j =Settings.col-1;i>=0 ; j--){
   if (i <0||j<0)break;
   if (Settings.grid[i+1][j]==666){ 
    //checking if the space below has the 666 ID (666 ID equals to blank)                   
    Settings.grid[i+1][j]=Settings.grid[i][j]; //Deleting the current blank                 
   }
  }
 }
}

注意: Settings.row and Settings.colsomething.lenght相似, something.lenght意味着它们具有网格的长度,即使网格从0开始。

在这种情况下,如何避免outofBounds错误?

  • 在第3行:

      for (j =Settings.col-1;i>=0 ; j--){ 

改成:

                for (j =Settings.col-1;j>=0 ; j--){
  • 然后可以删除if行。

  • 然后在Settings.row-2上启动i

  • 尝试这个:

      public static void dropBall(){ for (i =Settings.row-1;i>=0;i--){ for (j =Settings.col-1;j>=0 ; j--){ if (Settings.grid[i+1][j]==666){ //checking if the space below has the 666 ID (666 ID equals to blank) Settings.grid[i+1][j]=Settings.grid[i][j]; //Deleting the current blank Settings.grid[i][j] = 666; } } } } 
  1. 从底部的第二行开始,而不是从第一行开始(因为它下面没有行):

      for (i = Settings.row-2 ... // instead of row-1 
  2. 删除此行(这是多余的):

      if (i <0||j<0)break; 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM