152-data_structure-12-set~349两个数组的交集
概述
给定两个数组,编写一个函数来计算它们的交集。
说明:
- 输出结果中的每个元素一定是唯一的。
- 我们可以不考虑输出结果的顺序。
测试
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解题思路
求交集且无序唯一
使用集合
解题步骤
用集合对nums1去重
遍历nums1,筛选出nums2也包含的值
代码
/**
* @param {number[]} nums1
* @param {number[]} nums2
* @return {number[]}
*/
var intersection = function(nums1, nums2) {
return [...new Set(nums1)].filter(n => nums2.includes(n))
};
复杂度
- 时间复杂度:O(m * n),m为nums1的长度,n为nums2的长度
- 空间复杂度:O(m)