[英]Flatten 2d or 3d Array in Java
我需要采取一個多維數組並將其展平,以便該數組看起來像:
[1,2,3]
[4,5,6]
然后將其轉換為:
[1,2,3,4,5,6]
我還需要容納3D陣列並對其進行展平。
這是我到目前為止所得到的...
class ArrayOperations {
private int[] postFlattenedArray;
public ArrayOperations {
flattenedArray = new int[arrayDimensions[0]];
// arrayDimesnsions of 3,4 is a a 3x4 array; 3,4,5 is a 3x4x5 array
//set up ints to hold total size and dimensionality of array
int prod = 1
int dimensions = 0;
newArray = new int[prod - 1];
for (int i: arrayDimensions) {
prod = prod * i;
dimensions += 1;
}
int k = 0;
for ( int i: arrayDimensions ){
for ( int j = 0; j <= i; j++ ){
newArray[k++] = flattenedArray[j][0][0]
}
}
}
我知道我需要運行一些嵌套的for循環,但是我很難理解如何對不同的數組維執行此操作。 因此,如果數組具有維; 3,5,6那么我不確定如何運行循環,以便像這樣迭代:
[1..4][0][0], [0][1..5][0], [0][0][1..6]
似乎最簡單的解決方案是實現遞歸函數flatten
(可能必須通用才能處理任何數組),如果已經平坦或在所有內部數組上遞歸調用自身,則它將返回數組本身。連接結果。
嘗試這個。
static void flatten(Object object, List<Integer> list) {
if (object.getClass().isArray())
for (int i = 0; i < Array.getLength(object); ++i)
flatten(Array.get(object, i), list);
else
list.add((int)object);
}
static int[] flatten(Object object) {
List<Integer> list = new ArrayList<>();
flatten(object, list);
int size = list.size();
int[] result = new int[size];
for (int i = 0; i < size; ++i)
result[i] = list.get(i);
return result;
}
和
int[][][] array = {
{{1, 2, 3}, {4, 5}},
{{6}, {7, 8, 9}},
};
System.out.println(Arrays.toString(flatten(array)));
// -> [1, 2, 3, 4, 5, 6, 7, 8, 9]
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.