前端javascript面試題:給定一個不重複集合,編寫代碼,能夠輸出其所有子集合。



問題:給定一個不重複集合,編寫代碼,能夠輸出其所有子集合。例如對於輸入集合[1,2,3],返回以下集合,順序不限:

[
  [],       [ 1 ],
  [ 2 ],    [ 2, 1 ],
  [ 3 ],    [ 3, 1 ],
  [ 3, 2 ], [ 3, 2, 1 ]
]

答案:

// function test(arr){
//     return arr.reduce(function (prev,next) {
//         return prev.concat(prev.map(item=>[next,...item]))
//     },[[]])
// }

// 箭頭函數版本
const test = arr=>(
    arr.reduce((prev,next)=>(
        prev.concat(prev.map(item=>[next,...item]))
    ),[[]])
)

console.log(test([1,2,3]));
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章