给定两个数组,编写一个函数来计算它们的交集。
示例:
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
说明:
代码:
//2020_06_29
class Solution {
public:
vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
vector<int> res;
unordered_map<int, int> um;
for (auto it = nums1.begin(); it != nums1.end(); it++) {
um[*it] = 1;//向量1插入哈希表
}
for (auto it = nums2.begin(); it != nums2.end(); it++) {
auto it2 = um.find(*it);
if (it2 != um.end()) {//查找哈希表
if (it2->second == 1) {//查到且是第一次查到
res.push_back(*it);//加入到结果向量
it2->second = 2;//修改value避免二次加入
}
}
}
return res;
}
};
原文:https://www.cnblogs.com/iceix/p/13209030.html