350.两个数组的交集 ②

目录

题目

给你两个整数数组 nums1 和 nums2 ,请你以数组形式返回两数组的交集。返回结果中每个元素出现的次数,应与元素在两个数组中都出现的次数一致(如果出现次数不一致,则考虑取较小值)。可以不考虑输出结果的顺序。

过程

思路1:分离双指针,两边先排序,然后都遍历,有点类似两个有序数组的合并。

解法

bash 复制代码
class Solution {
public:
    vector<int> intersect(vector<int>& nums1, vector<int>& nums2) {
        int s1=nums1.size();
        int s2=nums2.size();
        int left1=0;
        int left2=0;
        sort(nums1.begin(),nums1.end());
        sort(nums2.begin(),nums2.end());
        vector<int> s3;
        while(left1<s1 && left2<s2){
            if(nums1[left1]<nums2[left2]){
                left1++;
            }else if(nums1[left1]>nums2[left2]){
                left2++;
            }else{
                s3.push_back(nums1[left1]);
                left1++;
                left2++;
            }
        }
        return s3;
    }
};
相关推荐
垫脚摸太阳1 分钟前
二分查找经典算法题--数的范围
数据结构·算法
噜啦噜啦嘞好2 分钟前
算法篇:二分查找
数据结构·c++·算法·leetcode
setmoon2142 分钟前
C++中的构建器模式
开发语言·c++·算法
2301_815482932 分钟前
C++中的桥接模式变体
开发语言·c++·算法
yunyun321233 分钟前
C++与量子计算模拟
开发语言·c++·算法
吴声子夜歌4 分钟前
JavaScript——数组
java·javascript·算法
不知名。。。。。。。。9 分钟前
仿muduo库实现高并发服务器----HttpServer
运维·服务器·算法
暮冬-  Gentle°11 分钟前
移动设备上的C++优化
开发语言·c++·算法
2401_8747325313 分钟前
C++中的装饰器模式高级应用
开发语言·c++·算法
季明洵17 分钟前
回溯介绍及实战
java·数据结构·算法·leetcode·回溯