数据结构
给定两个数组,编写一个函数来盘算它们的交集。
示例 1:
输入: nums1 = [1,2,2,1], nums2 = [2,2]
输出: [2,2]
示例 2:
输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出: [4,9]
申明:
输出效果中每一个元素涌现的次数,应与元素在两个数组中涌现的次数一致。
我们能够不斟酌输出效果的递次。
代码完成
/**
* @param {number[]} nums1
* @param {number[]} nums2
* @return {number[]}
*/
var intersect = function(nums1, nums2) {
if(nums1.length === 0 || nums2.length === 0)
return [];
let arr1, arr2;
let map = {};
let res = [];
if(nums1.length > nums2.length) {
arr1 = nums2;
arr2 = nums1;
} else {
arr1 = nums1;
arr2 = nums2;
}
for(let i = 0;i < arr1.length;i++) {
if(map[arr1[i]] === void 0)
map[arr1[i]] = 1;
else
map[arr1[i]]++;
}
for(let i = 0;i < arr2.length;i++) {
if(map[arr2[i]] !== void 0) {
if(map[arr2[i]] > 0){
res.push(arr2[i]);
map[arr2[i]]--;
}
}
}
return res;
};