class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param nums1 int整型vector
     * @param nums2 int整型vector
     * @return int整型vector
     */
    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
        unordered_set<int> n1;
        n1.insert(nums1.begin(), nums1.end());
        set<int> st;
        for (const auto& x : nums2) {
            if (n1.find(x) != n1.end()) {
                st.insert(x);
            }
        }
        vector<int> ans;
        ans.assign(st.begin(), st.end());
        return ans;
    }
};

时间复杂度:O(n),遍历数组

空间复杂度:O(n),存储集合