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;
    }
};
相关推荐
白熊1886 分钟前
【机器学习基础】机器学习入门核心算法:层次聚类算法(AGNES算法和 DIANA算法)
算法·机器学习·聚类
晨曦学习日记1 小时前
力扣题解654:最大二叉树
数据结构·算法·leetcode
PXM的算法星球1 小时前
paoxiaomo的XCPC算法竞赛训练经验
c++·算法
孤独得猿1 小时前
高阶数据结构——并查集
数据结构·c++·经验分享·算法
闪电麦坤951 小时前
数据结构:递归(Recursion)
数据结构
一只鱼^_1 小时前
力扣第452场周赛
数据结构·c++·算法·leetcode·贪心算法·动态规划·剪枝
apolloyhl1 小时前
C/C++ 面试复习笔记(2)
c语言·c++·算法·面试
数据皮皮侠AI3 小时前
中国城市间地理距离矩阵(2024)
大数据·人工智能·线性代数·算法·矩阵·动态规划·制造
GEEK零零七3 小时前
Leetcode 2123. 使矩阵中的 1 互不相邻的最小操作数
算法·leetcode··二分图·匈牙利算法·hopcroft-karp算法
武子康4 小时前
大数据-275 Spark MLib - 基础介绍 机器学习算法 集成学习 随机森林 Bagging Boosting
大数据·算法·机器学习·ai·语言模型·spark-ml·集成学习