veces es más fácil y siempre limpia para poner la búsqueda de un método separado:
private Point find2DIndex(Object[][] array, Object search) {
if (search == null || array == null) return null;
for (int rowIndex = 0; rowIndex < array.length; rowIndex++) {
Object[] row = array[rowIndex];
if (row != null) {
for (int columnIndex = 0; columnIndex < row.length; columnIndex++) {
if (search.equals(row[columnIndex])) {
return new Point(rowIndex, columnIndex);
}
}
}
}
return null; // value not found in array
}
Esto devolverá el primer partido solamente. Si necesita todo, recopile todos los puntos en una lista y devuelva esa lista al final.
Uso:
private void doSomething() {
String[][] array = {{"one", "1"},{"two","2"}, {"three","3"}};
Point index = find2DIndex(array, "two");
// change one value at index
if (index != null)
array[index.x][index.y] = "TWO";
// change everything in the whole row
if (index != null) {
String[] row = array[index.x];
// change the values in that row
}
}
favor reformular su pregunta. Las "matrices bidimensionales" en Java son solo matrices de matrices, así que si tiene 'String [] [] matrix = ...', entonces la primera dimensión 'matrix [i]' tiene type 'String []', no 'String'. –