假设我在java中有不到十个表示矩阵的二维数组。每个数组都是从0到6枚举的。每个数组都要大n*2^enumval,其中n是第0个枚举数组中的元素数,因此我的多维数组几乎是金字塔形的,因此需要锯齿状的三维数组。有可能创建一个锯齿状的三维数组吗?
int[][] array0 = new int[2][2];
int[][] array1 = new int[4][4];
int[][] array2 = new int[8][8];
int[][] array3 = new int[16][16];
int[][][] arrayStorage = new int[][][];
我想用以下方法存储数组:arrayStorage[columnOfArray#][rowOfArray#1][#]
是的,用Java创建锯齿状数组是完全可能的。
下面是一些示例语法:
int[][] jagged = new int[3][];
jagged[0] = new int[]{1, 2, 4};
jagged[1] = new int[]{9, 17, 35, 80};
jagged[2] = new int[]{100};
在这个例子中,我有一个锯齿状的数组,有三行,但列的数量不确定。它们的长度从1到4不等。
Java仅支持锯齿状数组。你正在寻找的3D阵列的一个例子(使用"矩阵"的"列表"作为更相关的具体例子):
// an array of m*n (or jagged) 2D arrays.
int[][][] matrices = new int[2][][];
// A 2*2 matrix
int[][] matrix22 = new int[2][];
matrix22[0] = new int[] {1, 2};
matrix22[1] = new int[] {3, 4};
matrices[0] = matrix22;
// A 3*3 matrix
int[][] matrix33 = new int[3][];
matrix33[0] = new int[] {1, 2, 3};
matrix33[1] = new int[] {4, 5, 6};
matrix33[2] = new int[] {7, 8, 9};
matrices[1] = matrix33;
或者,听一句话:
int[][][] matrices2 = new int[][][] {
new int[][] {
new int[] {1, 2},
new int[] {3, 4}
},
new int[][] {
new int[] {1, 2, 3},
new int[] {4, 5, 6},
new int[] {7, 8, 9}
}
};