Add isDisjoint

This commit is contained in:
Isabelle Viktoria Maciohsek
2020-10-11 11:53:01 +03:00
parent a406ddcb34
commit 991bc8b400

21
snippets/isDisjoint.md Normal file
View File

@ -0,0 +1,21 @@
---
title: isDisjoint
tags: array,intermediate
---
Checks if the two iterables are disjointed (have no common values).
- Use the `new Set()` constructor to create a new `Set` object from each iterable.
- Use `Array.prototype.every()` and `Set.prototype.has()` to check that the two iterables have no common values.
```js
const isDisjoint = (a, b) => {
const sA = new Set(a), sB = new Set(b);
return [...sA].every(v => !sB.has(v));
};
```
```js
isDisjoint(new Set([1, 2]), new Set([3, 4])); // true
isDisjoint(new Set([1, 2]), new Set([1, 3])); // false
```