簡體   English   中英

用Java展平2d或3d數組

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM