检查相邻元素java 2d数组

时间:2014-07-05 13:41:38

标签: java multidimensional-array

我们说我有一个4X4 2D阵列。 例如

| 0 | 1 | 2 | 3 |
| 4 | 5 | 6 | 7 | 
| 8 | 9 | 10| 11|
| 12| 13| 14| 15| 

我需要向下和向左检查相邻元素,并且相邻的元素不会超出范围。例如0 {1,4},3 {2,7},5 {1,4,6,9}。

任何帮助?

由于

其他炎症。

grid = new boolean [][];
        for(int i=0;i<grid.length;i++){
            for(j=0;j<grid.length; j++)
            grid[i][j] = false;

        }  
  grid[0][1]= true;

if(grid[i][j+1]]==true){
    //do sth
}else if(grid[i][j-1]==true){
       // do sth
    }else if(grid[i-1][j]==true){
        //    do sth
        }else if(grid[i+1][j]==true){
           //     do sth
            }

1 个答案:

答案 0 :(得分:0)

将边界检查添加到if语句的前端。例如:

if ((j + 1) < grid[i].length && grid[i][j + 1] == true)

这将确保您不会使用j + 1超出界限。首先检查最左边的条件,如果是假,则由于&amp;&amp;和&amp;而且整个语句都是假的。操作

因此,第二个条件grid[i][j + 1] == true甚至不会被评估,你将避免IndexOutOfBoundsException。