我们说我有一个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
}
答案 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。