我有一个String[][] field
.例如,它可能看起来像:
[xy] [xy] [xy] [xy] [xy]
[xy] [xy] [xy] [xy] [xy]
[xy] [xy] [xy] [xy] [xy]
[xy] [xy] [xy] [xy] [xy]
[xy] [xy] [xy] [xy] [xy]
行数和列数相等,但每次的数量可能不同。我需要检查整行或整列元素的值是否相等。我已经为 3x3 编写了一些糟糕的代码field
来检查行,这里是:
public boolean checkHorizontal(String[][] field) {
boolean value = false;
int x = 0;
for (int i = 0; i < field.length; i++) {
if (field[i][x].equals(field[i][x + 1]) &&
field[i][x + 1].equals(field[i][x + 2]) &&
!field[i][x].equals("[something]")) {
value = true;
}
}
return value;
}
但这不是检查行的通用方法,因为我们可能有一个不同大小的矩阵(并且需要添加x + 3
、x + 4
、x + 5
等)。有没有有效的方法来比较二维数组的整行/整列?
检查所有行:
for(int i = 0; i < field.length; i++){
for(int j = 1; j < field[i].length; j++){
if(!field[i][0].equals(field[i][j])){
return false;
}
}
}
return true;
@quidproquo的答案实际上检查所有字段是否相等,但是将解决方案调整为单行或单列非常容易:
public boolean isEqual(String[][] data, int rowColumn, boolean row){
int i = 1;
int limit = (row) ? data[0].length : data.length;
while(i<limit){
if ((row) ? !data[rowColumn][i].equals(data[rowColumn][0])
: !data[i][rowColumn].equals(data[0][rowColumn]))
return false;
}
return true;
}