349. 两个数组的交集

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/intersection-of-two-arrays

给定两个数组 nums1nums2 ,返回 它们的交集

输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序

示例 1:

复制代码
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]

示例 2:

复制代码
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解释:[4,9] 也是可通过的

我们可以使用set和vector来实现这个题

1.用两个set包含进去(set可以去重)

2.比较

3.小的++,大的不东

如果相等把他放到vector中,都++

cpp 复制代码
class Solution {
public:
    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
        set<int> s1(nums1.begin(),nums1.end());
        set<int> s2(nums2.begin(),nums2.end());
        vector<int> ret;
        auto it1 =s1.begin();
        auto it2 =s2.begin();
        while(it1 != s1.end() &&it2 != s2.end())
        {
            if(*it1 <*it2)
            {
                it1++;
            }
            else if(*it1> *it2)
            {
                it2++;
            }
            else
            {
                ret.push_back(*it1);
                it1++;
                it2++;
            }
        }
        return ret;
    }
};
相关推荐
路人与大师27 分钟前
用算法实现 用统计的方式实现 用自然语言处理的方法实现 用大模型实现 专利精益化统计分析
人工智能·算法·自然语言处理
五点钟科技28 分钟前
大语言模型的完整训练周期从0到1的体系化拆解
算法·自然语言处理
Dxy12393102161 小时前
Python经典算法实战
开发语言·python·算法
五步晦暝1 小时前
【排序算法】典型排序算法 Java实现
java·算法·排序算法
巨龙之路1 小时前
【TDengine源码阅读】taosMemoryDbgInit函数
大数据·linux·c语言·tdengine
Dovis(誓平步青云)3 小时前
破解C/C++内存分配与管理:内存对象模型硬核剖析
开发语言·c++·内存管理·解读
小猿_004 小时前
C语言指针进阶
c语言·数据结构·算法
摆烂仙君5 小时前
小米2025年校招笔试真题手撕(二)
算法
Uncertainty!!6 小时前
C++编译/链接模型
c++·链接·编译