5種方式實現陣列扁平化

2022-07-17 03:00:12 字數 1094 閱讀 8562

陣列扁平化是指將乙個多維陣列變為一維陣列

[1, [2, 3, [4, 5]]]  ------>    [1, 2, 3, 4, 5]

遍歷陣列每一項,若值為陣列則遞迴遍歷,否則concat。

function

flatten(arr) , );

}

reduce是陣列的一種方法,它接收乙個函式作為累加器,陣列中的每個值(從左到右)開始縮減,最終計算為乙個值。

reduce包含兩個引數:**函式,傳給total的初始值

//

求陣列的各項值相加的和:

arr.reduce((total, item)=> , 0);

呼叫陣列的tostring方法,將陣列變為字串然後再用split分割還原為陣列

function

flatten(arr) )

}

因為split分割後形成的陣列的每一項值為字串,所以需要用乙個map方法遍歷陣列將其每一項轉換為數值型

和上面的tostring一樣,join也可以將陣列轉換為字串

function

flatten(arr) )

}

遞迴的遍歷每一項,若為陣列則繼續遍歷,否則concat

function

flatten(arr)

else

});return

res;

}

es6的擴充套件運算子能將二維陣列變為一維

.concat(...[1, 2, 3, [4, 5]]);  //

[1, 2, 3, 4, 5]

根據這個結果我們可以做乙個遍歷,若arr中含有陣列則使用一次擴充套件運算子,直至沒有為止。

function

flatten(arr)

return

arr;

}

雖然說寫了5種方法,但是核心也只有乙個:

遍歷陣列arr,若arr[i]為陣列則遞迴遍歷,直至arr[i]不為陣列然後與之前的結果concat。 

陣列扁平化

原陣列 const arr 1,2,3,4 5,6,7,8 9 希望輸出 1,2,3,4,5,6,7,8,9 方法一 遞迴 function arrdelayering arr else return newarr let newarr arrdelayering arr 1,2,3,4,5,6,7...

陣列扁平化

今天看到了陣列扁平化處理,猶記得之前面試被問到過,下面介紹一下陣列扁平化處理的幾種形式 題目要求 將陣列 arr 1,2,3,4,5,6,7,8,9 轉化為 1,2,3,4,5,6,7,8,9 1 遞迴 var arr 1,2,3,4,5,6,7,8,9 方法一 遞迴 function flatfu...

扁平化陣列

第一次遇到陣列扁平化已經是在3k遊戲的筆試題裡,當時是用了遞迴的方法。因為對一些陣列方法,字串方法十分的不熟練 扁平化陣列的核心都是,遍歷陣列元素,遇到陣列就拆,不是陣列就加進去。var arr 1,2,3,4,5 console.log bianpinghua arr tostring split...