挑战:
比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的差异。
例如:
diff([1, 2, 3, 5], [1, 2, 3, 4, 5]) 应该返回一个数组。
[“diorite”, “andesite”, “grass”, “dirt”, “pink wool”, “dead shrub”],
[“diorite”, “andesite”, “grass”, “dirt”, “dead shrub”]
应该返回 [“pink wool”]。
[“andesite”, “grass”, “dirt”, “pink wool”, “dead shrub”],
[“diorite”, “andesite”, “grass”, “dirt”, “dead shrub”]
应该返回 [“diorite”, “pink wool”]。
[“andesite”, “grass”, “dirt”, “dead shrub”],
[“andesite”, “grass”, “dirt”, “dead shrub”]
应该返回 []。
[1, 2, 3, 5],
[1, 2, 3, 4, 5]
应该返回 [4]。
[1, “calf”, 3, “piglet”],
[1, “calf”, 3, 4]
应该返回 [“piglet”, 4]。
[],
[“snuffleupagus”, “cookie monster”, “elmo”]
应该返回 [“snuffleupagus”, “cookie monster”, “elmo”]。
[1, “calf”, 3, “piglet”],
[7, “filly”]
应该返回 [1, “calf”, 3, “piglet”, 7, “filly”]。
答案:
方法 | 描述 |
---|---|
filter() | 检测数值元素,并返回符合条件所有元素的数组。 |
concat() | 连接两个或更多的数组,并返回结果。 |
indexOf() | 搜索数组中的元素,并返回它所在的位置。 |
function diff(arr1, arr2) {
var newArr = [];
newArr = arr1.filter(cur => arr2.indexOf(cur) === -1);
return newArr.concat(arr2.filter(cur => arr1.indexOf(cur) === -1));
}
diff([1, 2, 3, 5], [1, 2, 3, 4, 5]);
运行结果:
[4]
在线测试:
找出数组间差异算法挑战 | w3cschool