4.5 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
a5de63ebea8dbee56860f4f2 | Diferencia entre dos arreglos | 5 | 16008 | diff-two-arrays |
--description--
Compara dos arreglos y devuelve un nuevo arreglo con los elementos que sólo se encuentran en uno de los dos arreglos dados, pero no en ambos. En otras palabras, devuelve la diferencia simétrica de los dos arreglos.
**Nota:**Puedes devolver el arreglo con sus elementos en cualquier orden.
--hints--
diffArray([1, 2, 3, 5], [1, 2, 3, 4, 5])
debe devolver un arreglo.
assert(typeof diffArray([1, 2, 3, 5], [1, 2, 3, 4, 5]) === 'object');
["diorite", "andesite", "grass", "dirt", "pink wool", "dead shrub"], ["diorite", "andesite", "grass", "dirt", "dead shrub"]
debe devolver ["pink wool"]
.
assert.sameMembers(
diffArray(
['diorite', 'andesite', 'grass', 'dirt', 'pink wool', 'dead shrub'],
['diorite', 'andesite', 'grass', 'dirt', 'dead shrub']
),
['pink wool']
);
["diorite", "andesite", "grass", "dirt", "pink wool", "dead shrub"], ["diorite", "andesite", "grass", "dirt", "dead shrub"]
debe devolver un arreglo con un elemento.
assert(
diffArray(
['diorite', 'andesite', 'grass', 'dirt', 'pink wool', 'dead shrub'],
['diorite', 'andesite', 'grass', 'dirt', 'dead shrub']
).length === 1
);
["andesite", "grass", "dirt", "pink wool", "dead shrub"], ["diorite", "andesite", "grass", "dirt", "dead shrub"]
debe devolver ["diorite", "pink wool"]
.
assert.sameMembers(
diffArray(
['andesite', 'grass', 'dirt', 'pink wool', 'dead shrub'],
['diorite', 'andesite', 'grass', 'dirt', 'dead shrub']
),
['diorite', 'pink wool']
);
["andesite", "grass", "dirt", "pink wool", "dead shrub"], ["diorite", "andesite", "grass", "dirt", "dead shrub"]
debe devolver un arreglo con dos elementos.
assert(
diffArray(
['andesite', 'grass', 'dirt', 'pink wool', 'dead shrub'],
['diorite', 'andesite', 'grass', 'dirt', 'dead shrub']
).length === 2
);
["andesite", "grass", "dirt", "dead shrub"], ["andesite", "grass", "dirt", "dead shrub"]
debe devolver []
.
assert.sameMembers(
diffArray(
['andesite', 'grass', 'dirt', 'dead shrub'],
['andesite', 'grass', 'dirt', 'dead shrub']
),
[]
);
["andesite", "grass", "dirt", "dead shrub"], ["andesite", "grass", "dirt", "dead shrub"]
debe devolver un arreglo vacío.
assert(
diffArray(
['andesite', 'grass', 'dirt', 'dead shrub'],
['andesite', 'grass', 'dirt', 'dead shrub']
).length === 0
);
[1, 2, 3, 5], [1, 2, 3, 4, 5]
debe devolver [4]
.
assert.sameMembers(diffArray([1, 2, 3, 5], [1, 2, 3, 4, 5]), [4]);
[1, 2, 3, 5], [1, 2, 3, 4, 5]
debe devolver un arreglo con un elemento.
assert(diffArray([1, 2, 3, 5], [1, 2, 3, 4, 5]).length === 1);
[1, "calf", 3, "piglet"], [1, "calf", 3, 4]
debe devolver ["piglet", 4]
.
assert.sameMembers(diffArray([1, 'calf', 3, 'piglet'], [1, 'calf', 3, 4]), [
'piglet',
4
]);
[1, "calf", 3, "piglet"], [1, "calf", 3, 4]
debe devolver un arreglo con dos elementos.
assert(diffArray([1, 'calf', 3, 'piglet'], [1, 'calf', 3, 4]).length === 2);
[], ["snuffleupagus", "cookie monster", "elmo"]
debe devolver ["snuffleupagus", "cookie monster", "elmo"]
.
assert.sameMembers(diffArray([], ['snuffleupagus', 'cookie monster', 'elmo']), [
'snuffleupagus',
'cookie monster',
'elmo'
]);
[], ["snuffleupagus", "cookie monster", "elmo"]
debe devolver un arreglo con tres elementos.
assert(diffArray([], ['snuffleupagus', 'cookie monster', 'elmo']).length === 3);
[1, "calf", 3, "piglet"], [7, "filly"]
debe devolver [1, "calf", 3, "piglet", 7, "filly"]
.
assert.sameMembers(diffArray([1, 'calf', 3, 'piglet'], [7, 'filly']), [
1,
'calf',
3,
'piglet',
7,
'filly'
]);
[1, "calf", 3, "piglet"], [7, "filly"]
debe devolver un arreglo con seis elementos.
assert(diffArray([1, 'calf', 3, 'piglet'], [7, 'filly']).length === 6);
--seed--
--seed-contents--
function diffArray(arr1, arr2) {
const newArr = [];
return newArr;
}
diffArray([1, 2, 3, 5], [1, 2, 3, 4, 5]);
--solutions--
function diffArray(arr1, arr2) {
const newArr = [];
const h1 = Object.create(null);
arr1.forEach(function(e) {
h1[e] = e;
});
const h2 = Object.create(null);
arr2.forEach(function(e) {
h2[e] = e;
});
Object.keys(h1).forEach(function(e) {
if (!(e in h2)) newArr.push(h1[e]);
});
Object.keys(h2).forEach(function(e) {
if (!(e in h1)) newArr.push(h2[e]);
});
return newArr;
}