用Java初始化多维数组


81

声明多维数组并为其分配值的正确方法是什么?

这就是我所拥有的:

int x = 5;
int y = 5;

String[][] myStringArray = new String [x][y];

myStringArray[0][x] = "a string";
myStringArray[0][y] = "another string";

Answers:


64

尝试将适当的行替换为:

myStringArray[0][x-1] = "a string";
myStringArray[0][y-1] = "another string";

您的代码不正确,因为子数组的长度为y,索引从0开始。因此,设置为myStringArray[0][y]myStringArray[0][x]将失败,因为索引xy超出范围。

String[][] myStringArray = new String [x][y];是初始化矩形多维数组的正确方法。如果希望将其锯齿(每个子数组的长度可能不同),则可以使用类似于此答案的代码。但是请注意,在需要完美的矩形多维数组的情况下,John关于必须手动创建子数组的断言是错误的。


105

Java没有“真正的”多维数组。

例如,arr[i][j][k]等效于((arr[i])[j])[k]。换句话说,arr只是一个数组,一个数组,一个数组

因此,如果您知道数组的工作原理,那么您就会知道多维数组的工作原理!


宣言:

int[][][] threeDimArr = new int[4][5][6];

或者,使用初始化:

int[][][] threeDimArr = { { { 1, 2 }, { 3, 4 } }, { { 5, 6 }, { 7, 8 } } };

访问:

int x = threeDimArr[1][0][1];

要么

int[][] row = threeDimArr[1];

字符串表示形式:

Arrays.deepToString(threeDimArr);

产量

"[[[1, 2], [3, 4]], [[5, 6], [7, 8]]]"

有用的文章


3
那不是一个“真正的”多维数组吗?
dhardy

13
对于“真实”多维数组,我指的是“非锯齿状”数组。有关锯齿状数组和“真实”多维数组之间的区别,请参见此问题
aioobe

2
int[i][j][k]长度i,因此实际上等于((int[k])[j])[i]。声明中的大小相对于类型而言是反写的,我想使多维数组更类似于数学中的矩阵。
Milosz

感谢您提及Arrays.deepToString。
samir105 '19

60

您还可以使用以下构造:

String[][] myStringArray = new String [][] { { "X0", "Y0"},
                                             { "X1", "Y1"},
                                             { "X2", "Y2"},
                                             { "X3", "Y3"},
                                             { "X4", "Y4"} };

13

您可以声明多维数组,例如:

// 4 x 5 String arrays, all Strings are null
// [0] -> [null,null,null,null,null]
// [1] -> [null,null,null,null,null]
// [2] -> [null,null,null,null,null]
// [3] -> [null,null,null,null,null]

String[][] sa1 = new String[4][5];
for(int i = 0; i < sa1.length; i++) {           // sa1.length == 4
    for (int j = 0; j < sa1[i].length; j++) {     //sa1[i].length == 5
        sa1[i][j] = "new String value";
    }
}


// 5 x 0  All String arrays are null
// [null]
// [null]
// [null]
// [null]
// [null]
String[][] sa2 = new String[5][];
for(int i = 0; i < sa2.length; i++) {
    String[] anon = new String[ /* your number here */];
    // or String[] anon = new String[]{"I'm", "a", "new", "array"};
    sa2[i] = anon;
}

// [0] -> ["I'm","in","the", "0th", "array"]
// [1] -> ["I'm", "in", "another"]
String[][] sa3 = new String[][]{ {"I'm","in","the", "0th", "array"},{"I'm", "in", "another"}};

9

Java中的多维数组

返回多维数组

Java并不真正支持多维数组。在Java中,二维数组只是数组的数组,三维数组是数组的数组的数组,三维数组是数组的数组的数组,依此类推...

我们可以将二维数组定义为:

  1. int[ ] num[ ] = {{1,2}, {1,2}, {1,2}, {1,2}}

  2. int[ ][ ] num = new int[4][2]

    num[0][0] = 1;
    num[0][1] = 2;
    num[1][0] = 1;
    num[1][1] = 2;
    num[2][0] = 1;
    num[2][1] = 2;
    num[3][0] = 1;
    num[3][1] = 2;
    

    假设,如果您没有分配,num[2][1]它不会被初始化,然后它会自动分配0,即自动num[2][1] = 0

  3. 在下面,num1.length为您提供行。

  4. 虽然num1[0].length会为您提供与相关的元素数num1[0]。这里num1[0]有相关的阵列num1[0][0]num[0][1]只。

  5. 在这里,我们使用了一个for循环来帮助我们进行计算num1[i].length。下面i通过一个循环递增。

    class array
    {
        static int[][] add(int[][] num1,int[][] num2)
        {
            int[][] temp = new int[num1.length][num1[0].length];
            for(int i = 0; i<temp.length; i++)
            {
                for(int j = 0; j<temp[i].length; j++)
                {
                    temp[i][j] = num1[i][j]+num2[i][j];
                }
            }
            return temp;
        }
    
        public static void main(String args[])
        {
            /* We can define a two-dimensional array as
                 1.  int[] num[] = {{1,2},{1,2},{1,2},{1,2}}
                 2.  int[][] num = new int[4][2]
                     num[0][0] = 1;
                     num[0][1] = 2;
                     num[1][0] = 1;
                     num[1][1] = 2;
                     num[2][0] = 1;
                     num[2][1] = 2;
                     num[3][0] = 1;
                     num[3][1] = 2;
    
                     If you don't allocate let's say num[2][1] is
                     not initialized, and then it is automatically
                     allocated 0, that is, automatically num[2][1] = 0;
                  3. Below num1.length gives you rows
                  4. While num1[0].length gives you number of elements
                     related to num1[0]. Here num1[0] has related arrays
                     num1[0][0] and num[0][1] only.
                  5. Here we used a 'for' loop which helps us to calculate
                     num1[i].length, and here i is incremented through a loop.
            */
            int num1[][] = {{1,2},{1,2},{1,2},{1,2}};
            int num2[][] = {{1,2},{1,2},{1,2},{1,2}};
    
            int num3[][] = add(num1,num2);
            for(int i = 0; i<num1.length; i++)
            {
                for(int j = 0; j<num1[j].length; j++)
                    System.out.println("num3[" + i + "][" + j + "]=" + num3[i][j]);
            }
        }
    }
    

4

我要补充一点,如果您想阅读尺寸,可以这样做:

int[][][] a = new int[4][3][2];

System.out.println(a.length);  // 4
System.out.println(a[0].length); // 3
System.out.println(a[0][0].length); //2

您还可以使用锯齿状的数组,其中不同的行具有不同的长度,因此a[0].length != a[1].length


1
 int[][] myNums = { {1, 2, 3, 4, 5, 6, 7}, {5, 6, 7, 8, 9, 10, 11} };
 for (int x = 0; x < myNums.length; ++x) {
    for(int y = 0; y < myNums[i].length; ++y) {
       System.out.print(myNums[x][y]);
    }
 }

输出量

1 2 3 4 5 6 7 5 6 7 8 9 10 11


-3

您可以看一下开始:

    int [][][] i = {                //third dimension curly brace
                     {               // second dimension curly brace
                        {            //first dimension curly brace
                           1,1,1    //elements
                        },           
                    {3,3,3},    
                    {2,2,2}     
                      },
                      {
                         {
                          1,1,1
                         },
                         {3,3,3},
                         {2,2,2}
                       }
                    };      

2
这是答案还是什么?
maytham-ɯɐɥʇʎɐɯ

7
然后,我希望他是饿了吃
maytham-ɯɐɥʇʎɐɯ
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.