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%的用户
posted @ 2020-04-01 08:27  曲径通霄  阅读(190)  评论(0编辑  收藏  举报