在java中搜索二维数组

时间:2010-12-07 13:09:44

标签: java arrays

如何通过二维数组搜索[] [Name]?

当找到Name时,应返回Index,以便我可以更改该数组中的值。

[Index] [Values]。

此外,语法如何查找存储到找到的数组? [] [指数]。循环索引并设置一个值。 [0] [1] =等等。

由于

3 个答案:

答案 0 :(得分:7)

有时,将搜索放在单独的方法中会更容易,也更简洁:

 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
 }

这将仅返回第一场比赛。如果您需要全部,请收集列表中的所有点并在结尾处返回该列表。


用法:

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
  }

}

答案 1 :(得分:3)

由于您的评论而更新:

for(String[] subarray : array){
   int foundIndex = -1;
   for(int i = 0; i < subarray.length; i++){
      if(subarray[i].equals(searchString)){
         foundIndex = i;
         break;
      }
   } 
   if(foundIndex != -1){
      // change all values that are not at position foundIndex
      for(int i = 0; i < subarray.length; i++){
         if(i != foundIndex){
            subarray[i] = "something";
         }
      } 
      break;
   }
}

答案 2 :(得分:3)

最基本的方式是

for(int xIndex = 0 ; xIndex < 3 ; xIndex++){
for(int yIndex = 0 ; yIndex < 3 ; yIndex++){
      if(arr[xIndex][yIndex].equals(stringToSearch)){
             System.out.println("Found at"+ xIndex +"," + yIndex);

             for(int remainingIndex = 0 ; remainingIndex  < 3 ; remainingIndex++  ){
                    arr[xIndex][remainingIndex]="NEW VALUES";
             }
             break;
      }
}
}