在 java 中对二维数组使用 indexOf

Use indexOf for 2D array in java

您好,我创建了一个二维数组,我想从数组中的前 2 个数组中找到位置。然后在新的 ArrayList 中添加索引。但是这段代码不起作用。对这个问题有什么想法吗?

import java.util.ArrayList;

class Test {
    public static void main(String[] args) {

        ArrayList<Integer> tableau = new ArrayList<Integer>();
        int[][] tab = {
                        {1,1,1,1,1,1,2,1,1,2,1,1,1,2,1,2,1,1,1,1,1},
                        {1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,1,1,1},
                    };

        for (int i = 0; i < tab.length; i++) {
            int j = tab[i].indexOf(2);
            for (int k = j ; k < tab[i].length; k++) {
                if (tab[i][j] == 2){
                    tableau.add(j);
                }
            }

        }
        for (Integer row : tableau) {
                System.out.println("row = "+ Arrays.toString(tableau));
        }
    }
}

正如其他人提到的,常规数组没有 indexOf 方法,这意味着您在编译时会出错。

但是,您可以轻松创建自己的方法作为替代方法。

private static int indexOf(int value, int[] array)
{
    for (int i=0; i<array.length; i++)
    {
        if (array[i] == value)
            return i;
    }
    return -1;
}

然后你可以只替换这一行:

int j = tab[i].indexOf(2);

有了这个:

int j = indexOf(2, tab[i]);