Ініціалізація багатовимірного масиву в Java


81

Який правильний спосіб оголосити багатовимірний масив і призначити йому значення?

Це те, що я маю:

int x = 5;
int y = 5;

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

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

Відповіді:


64

Спробуйте замінити відповідні рядки на:

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

Ваш код неправильний, оскільки підмасиви мають довжину y, а індексація починається з 0. Тож установка myStringArray[0][y]або myStringArray[0][x]не вдасться, оскільки індекси xта yпоза межами.

String[][] myStringArray = new String [x][y];є правильним способом ініціалізації прямокутного багатовимірного масиву. Якщо ви хочете, щоб він був зубчастим (кожен підмасив потенційно має різну довжину), тоді ви можете використовувати код, подібний до цієї відповіді . Однак зверніть увагу, що твердження Джона про те, що вам потрібно створювати підмасиви вручну, є неправильним у тому випадку, коли ви хочете мати ідеально прямокутний багатовимірний масив.


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]. Розміри в декларації записуються назад щодо типів, я думаю, щоб зробити багатовимірні масиви більш схожими на матриці в математиці.
Мілош

Дякуємо, що згадали Arrays.deepToString.
samir105

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-ɯɐɥʇʎɐɯ
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.