Який правильний спосіб оголосити багатовимірний масив і призначити йому значення?
Це те, що я маю:
int x = 5;
int y = 5;
String[][] myStringArray = new String [x][y];
myStringArray[0][x] = "a string";
myStringArray[0][y] = "another string";
Який правильний спосіб оголосити багатовимірний масив і призначити йому значення?
Це те, що я маю:
int x = 5;
int y = 5;
String[][] myStringArray = new String [x][y];
myStringArray[0][x] = "a string";
myStringArray[0][y] = "another string";
Відповіді:
Спробуйте замінити відповідні рядки на:
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];
є правильним способом ініціалізації прямокутного багатовимірного масиву. Якщо ви хочете, щоб він був зубчастим (кожен підмасив потенційно має різну довжину), тоді ви можете використовувати код, подібний до цієї відповіді . Однак зверніть увагу, що твердження Джона про те, що вам потрібно створювати підмасиви вручну, є неправильним у тому випадку, коли ви хочете мати ідеально прямокутний багатовимірний масив.
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]]]"
int[i][j][k]
має довжину i
, тому насправді це еквівалентно ((int[k])[j])[i]
. Розміри в декларації записуються назад щодо типів, я думаю, щоб зробити багатовимірні масиви більш схожими на матриці в математиці.
Ви можете оголосити багатовимірні масиви, як:
// 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"}};
Java не відповідає дійсності підтримує багатовимірні масиви. У Java двовимірний масив - це просто масив масивів, тривимірний масив - це масив масивів масивів, чотиривимірний масив - масив масивів масивів масивів тощо ...
Ми можемо визначити двовимірний масив як:
int[ ] num[ ] = {{1,2}, {1,2}, {1,2}, {1,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
;
Внизу - num1.length
рядки.
Поки num1[0].length
дає вам кількість елементів, пов'язаних з num1[0]
. Тут num1[0]
є пов'язані масиви num1[0][0]
і num[0][1]
тільки.
Тут ми використали 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]);
}
}
}
Додам, що якщо ви хочете прочитати розміри, ви можете зробити це:
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
.
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
Ви можете подивитися на це, щоб почати:
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}
}
};