在java中创建一个三维锯齿状数组来存储不同大小的二维数组



假设我在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}
    }
};

最新更新