[英]Use indexOf for 2D array in java
您好,我创建了一个2D数组,我想从数组的前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]);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.