数据结构
给定两个数组,编写一个函数来计算它们的交集。
示例 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;
};
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。