声明多维数组并为其分配值的正确方法是什么?
这就是我所拥有的:
int x = 5;
int y = 5;
String[][] myStringArray = new String [x][y];
myStringArray[0][x] = "a string";
myStringArray[0][y] = "another string";
Answers:
尝试将适当的行替换为:
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];
是初始化矩形多维数组的正确方法。如果希望将其锯齿(每个子数组的长度可能不同),则可以使用类似于此答案的代码。但是请注意,在需要完美的矩形多维数组的情况下,John关于必须手动创建子数组的断言是错误的。
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[][] 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}
}
};