Files
30-seconds-of-code/snippets/js/s/powerset.md
2023-05-07 16:07:29 +03:00

22 lines
497 B
Markdown

---
title: Powerset
type: snippet
language: javascript
tags: [math,algorithm]
cover: new-plant
dateModified: 2021-09-27T15:27:07+02:00
---
Returns the powerset of a given array of numbers.
- Use `Array.prototype.reduce()` combined with `Array.prototype.map()` to iterate over elements and combine into an array containing all combinations.
```js
const powerset = arr =>
arr.reduce((a, v) => a.concat(a.map(r => r.concat(v))), [[]]);
```
```js
powerset([1, 2]); // [[], [1], [2], [1, 2]]
```