Merge pull request #709 from EthanOrange/patch-3
Update symmetricDifference, add uniqueSymmetricDifference
This commit is contained in:
@ -1,6 +1,6 @@
|
||||
### symmetricDifference
|
||||
|
||||
Returns the symmetric difference between two arrays.
|
||||
Returns the symmetric difference between two arrays, without filtering out duplicate values.
|
||||
|
||||
Create a `Set` from each array, then use `Array.filter()` on each of them to only keep values not contained in the other.
|
||||
|
||||
@ -14,4 +14,5 @@ const symmetricDifference = (a, b) => {
|
||||
|
||||
```js
|
||||
symmetricDifference([1, 2, 3], [1, 2, 4]); // [3, 4]
|
||||
symmetricDifference([1, 2, 2], [1, 3, 1]); // [2, 2, 3]
|
||||
```
|
||||
|
||||
16
snippets/uniqueSymmetricDifference.md
Normal file
16
snippets/uniqueSymmetricDifference.md
Normal file
@ -0,0 +1,16 @@
|
||||
### uniqueSymmetricDifference
|
||||
|
||||
Returns the unique symmetric difference between two arrays, not containing duplicate values from either array.
|
||||
|
||||
Use `Array.filter()` and `Array.includes()` on each array to remove values contained in the other, then create a `Set` from the results, removing duplicate values.
|
||||
|
||||
```js
|
||||
const uniqueSymmetricDifference = (a, b) => [
|
||||
...new Set([...a.filter(v => !b.includes(v)), ...b.filter(v => !a.includes(v))])
|
||||
];
|
||||
```
|
||||
|
||||
```js
|
||||
uniqueSymmetricDifference([1, 2, 3], [1, 2, 4]); // [3, 4]
|
||||
uniqueSymmetricDifference([1, 2, 2], [1, 3, 1]); // [2, 3]
|
||||
```
|
||||
@ -302,6 +302,7 @@ unionWith:array,function
|
||||
uniqueElements:array
|
||||
uniqueElementsBy:array,function
|
||||
uniqueElementsByRight:array,function
|
||||
uniqueSymmetricDifference:array,math
|
||||
untildify:node,string
|
||||
unzip:array
|
||||
unzipWith:array,function,advanced
|
||||
|
||||
@ -7,3 +7,6 @@ test('symmetricDifference is a Function', () => {
|
||||
test('Returns the symmetric difference between two arrays.', () => {
|
||||
expect(symmetricDifference([1, 2, 3], [1, 2, 4])).toEqual([3, 4]);
|
||||
});
|
||||
test('Returns duplicates from one array', () => {
|
||||
expect(symmetricDifference([1, 2, 2], [1, 3, 1])).toEqual([2, 2, 3]);
|
||||
});
|
||||
|
||||
@ -0,0 +1,4 @@
|
||||
const uniqueSymmetricDifference = (a, b) => [
|
||||
...new Set([...a.filter(v => !b.includes(v)), ...b.filter(v => !a.includes(v))])
|
||||
];
|
||||
module.exports = uniqueSymmetricDifference;
|
||||
@ -0,0 +1,12 @@
|
||||
const expect = require('expect');
|
||||
const uniqueSymmetricDifference = require('./uniqueSymmetricDifference.js');
|
||||
|
||||
test('uniqueSymmetricDifference is a Function', () => {
|
||||
expect(uniqueSymmetricDifference).toBeInstanceOf(Function);
|
||||
});
|
||||
test('Returns the symmetric difference between two arrays.', () => {
|
||||
expect(uniqueSymmetricDifference([1, 2, 3], [1, 2, 4])).toEqual([3, 4]);
|
||||
});
|
||||
test('Does not return duplicates from one array', () => {
|
||||
expect(uniqueSymmetricDifference([1, 2, 2], [1, 3, 1])).toEqual([2, 3]);
|
||||
});
|
||||
Reference in New Issue
Block a user