leetcode 349. 两个数组的交集
问题描述
给定两个数组,编写一个函数来计算它们的交集。
示例 1:
输入: nums1 = [1,2,2,1], nums2 = [2,2]
输出: [2]
示例 2:
输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出: [9,4]
说明:
输出结果中的每个元素一定是唯一的。
我们可以不考虑输出结果的顺序。
代码
class Solution {
public:
vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
int m = nums1.size(),n = nums2.size(),i;
map<int,int>table;
vector<int> ans;
for(i = 0; i < m; ++i)
{
table[nums1[i]]++;
}
for(i = 0; i < n; ++i)
{
if(table[nums2[i]]!=0)
{
ans.push_back(nums2[i]),
table[nums2[i]] = 0;
}
}
return ans;
}
};
结果:
执行用时 :16 ms, 在所有 C++ 提交中击败了21.13%的用户
内存消耗 :11 MB, 在所有 C++ 提交中击败了5.47%的用户
代码
class Solution {
public:
vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
unordered_set<int> s1(nums1.begin(),nums1.end()),ans;
for(auto iter:nums2)
{
if(s1.count(iter))
ans.insert(iter);
}
return vector<int>(ans.begin(),ans.end());
}
};
结果:
执行用时 :12 ms, 在所有 C++ 提交中击败了48.98%的用户
内存消耗 :10.4 MB, 在所有 C++ 提交中击败了5.47%的用户
代码
class Solution {
public:
vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
vector<int> ans;
sort(nums1.begin(),nums1.end());
sort(nums2.begin(),nums2.end());
int m = nums1.size(),n = nums2.size(),i=0,j=0;
while(i < m && j < n)
{
if(nums1[i] > nums2[j])++j;
else if(nums1[i] < nums2[j])++i;
else{
if(ans.empty() || ans.back()!= nums1[i])
ans.push_back(nums1[i]);
++i;++j;
}
}
return ans;
}
};
结果:
执行用时 :16 ms, 在所有 C++ 提交中击败了21.13%的用户
内存消耗 :10.2 MB, 在所有 C++ 提交中击败了5.47%的用户