如何将2维数组int originalArray[][]
展平为1维数组?
int a [] = {1,2,6,7,2};
int b [] = {2,44,55,2};
int c [] = {2,44,511,33};
int originalArray [][] = new int[][]{a,b,c};
答案 0 :(得分:41)
答案 1 :(得分:26)
使用Java 8,您可以“flatMap”内部数组:
int[] flatArray = Arrays.stream(originalArray)
.flatMapToInt(Arrays::stream)
.toArray();
或:
int[] flatArray = Stream.of(a, b, c)
.flatMapToInt(Arrays::stream)
.toArray();
答案 2 :(得分:7)
一个简单的for循环可以做,这并不困难,但取决于你要复制值的顺序。例如(基于在您的示例中数组都具有相同长度的事实):
int[] newArray = new int[3 * a.length];
int index = 0;
for (int n = 0; n < a.length; n++) {
newArray[index++] = a[n];
newArray[index++] = b[n];
newArray[index++] = c[n];
}
或(不同的顺序,a,b,c可以有不同的长度):
int[] newArray = new int[a.length + b.length + c.length];
System.arraycopy(a, 0, newArray, 0, a.length);
System.arraycopy(b, 0, newArray, a.length, b.length);
System.arraycopy(c, 0, newArray, a.length + b.length, c.length);
答案 3 :(得分:4)
将有两个步骤:
1)找出创建新向量的元素总数(1d数组)
2)以预定义的顺序迭代你的2d数组并将其元素复制到创建的向量
int elementsNumber = 0;
for (int i = 0; i < originalArray.length; i++) {
elementsNumber += originalArray[i].length;
}
int[] newArray = new int[elementsNumber];
int j = 0;
for (int i = 0; i < originalArray.length; i++) {
System.arrayCopy (originalArray[i], 0, newArray, j, originalArray[i].length);
j += originalArray[i].length;
}
答案 4 :(得分:2)
由于无法扩展数组(即必须在初始化时声明错误的大小),因此必须遍历数组两次:
int size = 0;
for (int[] ar : originalArray) size += ar.length;
int[] result = new int[size];
int pos = 0;
for (int[] ar : originalArray) {
System.arraycopy(ar, 0, result, pos, ar.length);
pos += ar.length;
}
答案 5 :(得分:2)
int[] oneDArray = new int[arr.length*arr.length];
//Flatten 2D array to 1D array...
int s = 0;
for(int i = 0; i < arr.length; i ++)
for(int j = 0; j < arr.length; j ++){
oneDArray[s] = arr[i][j];
s++;
}
答案 6 :(得分:0)
带有 IntStream
IntStream.concat(
IntStream.concat( IntStream.of(originalArray[0]), IntStream.of(originalArray[1]) ),
IntStream.of(originalArray[2]) ).toArray();
获取:[1, 2, 6, 7, 2, 2, 44, 55, 2, 2, 44, 511, 33]
答案 7 :(得分:-1)
计算originalArray中元素的总数。创建该长度的新数组。将元素逐个复制到新数组中。
我不熟悉任何库函数。