您好我创建了一个2D数组,我想找到数组中前两个的位置。然后在新的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));
}
}
}
答案 0 :(得分:0)
正如其他人所提到的,常规数组没有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]);