fix(curriculum): add two edge test cases to the sorted union problem (#44860)

* fix: fixed solution of sorted union

* fix: improved solution of sorted union problem
This commit is contained in:
Vaibhav
2022-02-02 23:58:31 +05:30
committed by GitHub
parent 3cee5509e6
commit 9ffc7b4711

View File

@ -45,6 +45,18 @@ assert.deepEqual(uniteUnique([1, 2, 3], [5, 2, 1, 4], [2, 1], [6, 7, 8]), [
]);
```
`uniteUnique([1, 3, 2], [5, 4], [5, 6])` should return `[1, 3, 2, 5, 4, 6]`.
```js
assert.deepEqual(uniteUnique([1, 3, 2], [5, 4], [5, 6]), [1, 3, 2, 5, 4, 6]);
```
`uniteUnique([1, 3, 2, 3], [5, 2, 1, 4], [2, 1])` should return `[1, 3, 2, 5, 4]`.
```js
assert.deepEqual(uniteUnique([1, 3, 2, 3], [5, 2, 1, 4], [2, 1]), [1, 3, 2, 5, 4]);
```
# --seed--
## --seed-contents--
@ -62,7 +74,11 @@ uniteUnique([1, 3, 2], [5, 2, 1, 4], [2, 1]);
```js
function uniteUnique(arr) {
return [].slice.call(arguments).reduce(function(a, b) {
return [].concat(a, b.filter(function(e) {return a.indexOf(e) === -1;}));
return [].concat(
a,
b.filter(function(e, currentIndex) {
return b.indexOf(e) === currentIndex && a.indexOf(e) === -1;
}));
}, []);
}
```