我有一个二维数组列表
ArrayList<ArrayList<String>> list = new ArrayList<ArrayList<String>>();
我想获取在 (0,0) 位置的项目。
我正在寻找类似以下的内容:
list.get(0,0)
谢谢!
我有一个二维数组列表
ArrayList<ArrayList<String>> list = new ArrayList<ArrayList<String>>();
我想获取在 (0,0) 位置的项目。
我正在寻找类似以下的内容:
list.get(0,0)
谢谢!
你必须使用
list.get(0).get(0)
因为您使用的不是真正的二维List
而是Lists
的List
。
Java没有2D列表(或数组)。可以使用类似以下方式的方法:
list.get(0).get(0)
array[0,0] // WRONG! This isn't Fortran!
相反,你应该这样做:
array[0][0]
String value = list.get(0).get(0);
这是一个用于遍历2D-ArrayList的程序。在此程序中,您可以使用列表(i,j)中的项目而不是LineX :-)
程序:
Scanner scan = new Scanner(System.in);
int no_of_rows = scan.nextInt(); //Number of rows
int no_of_columns = scan.nextInt(); //Number of columns
ArrayList<ArrayList<String>> list = new ArrayList<>();
for (int i = 0; i < no_of_rows; i++) {
list.add(new ArrayList<>()); //For every instance of row create an Arraylist
for (int j = 0; j < no_of_columns; j++) {
list.get(i).add(scan.next()); //Specify values for each indices
}
}
//ArrayList Travesal
for (int i = 0; i < list.size(); i++) {
for (int j = 0; j < list.get(i).size(); j++) {
System.out.print(list.get(i).get(j)+" "); //LineX
}
System.out.println();
}
输出:
2 3
1 2 3 4 5 6
1 2 3
4 5 6
String val = list.get(0).get(0);
我们可以使用以下语法来满足我们的要求: arrIJ=arr.get(i).get(j);
我需要找到2D列表的对角线差异,我使用了上述语法:
对角线差异代码:
public static int diagonalDifference(**List<List<Integer>> arr**) {
int size=arr.size();
int forwardDiagonal=0;
int backwardDiagonal=0;
for(int i=0;i<size;i++){
for(int j=0;j<size;j++){
if(i==j){
forwardDiagonal=forwardDiagonal+**arr.get(i).get(j)**;
}
}
}
for(int i=size-1;i>=0;i--){
for(int j=0;j<size;j++){
if(i+j==size-1){
backwardDiagonal=backwardDiagonal+**arr.get(i).get(j)**;
}
}
}
return Math.abs(forwardDiagonal-backwardDiagonal);
}