問題:給定一個不重複集合,編寫代碼,能夠輸出其所有子集合。例如對於輸入集合[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]));