问题:给定一个不重复集合,编写代码,能够输出其所有子集合。例如对于输入集合[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]));
网友评论