我们需要编写一个JavaScript函数,该函数接受两个数字数组,分别称为arr1和arr2。
该函数应基于两个输入数组构建第三个数组,该数组包含arr1和arr2共同的所有元素。
请注意,如果两个数组中都存在一个以上相同的元素,则我们必须考虑该元素的所有此类实例。
例如-
如果输入数组是-
const arr1 = [1, 2, 2, 4, 4, 5, 6]; const arr2 = [3, 2, 4, 2, 4, 9];
那么输出数组应该是-
const output = [2, 2, 4, 4];
以下是代码-
const arr1 = [1, 2, 2, 4, 4, 5, 6]; const arr2 = [3, 2, 4, 2, 4, 9]; const findIntersection = (arr1 = [], arr2 = []) => { const map = new Map(); for (const el of arr2) { const count = map.get(el) || 0; map.set(el, count + 1); }; return arr1.filter(el => { let count = map.get(el); if (count) { map.set(el, --count); return true; } return false; }); }; console.log(findIntersection(arr1, arr2));输出结果
以下是控制台输出-
[2, 2, 4, 4]