当前位置: 首页 > news >正文

Leetcode350:两个数组的交集 II

题目描述:

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

代码思路:

  1. 参数检查与交换
    • 首先,方法检查两个列表的长度。如果nums2的长度小于nums1的长度,就交换这两个列表的角色,即调用self.intersect(nums2, nums1)。这样做的目的是为了优化性能,确保在后续步骤中处理的列表是较长的那个。因为使用Counter对较长的列表进行计数会更高效,同时在后续遍历较短的列表时,可以减少查找次数。
  2. 初始化结果列表和计数器
    • 定义一个空列表ans,用于存储最终的交集结果。
    • 使用Counter类(来自collections模块)对nums1进行计数,生成一个字典c,其中键是nums1中的元素,值是这些元素在nums1中出现的次数。
  3. 遍历较短列表并查找交集
    • 遍历nums2中的每个元素n
    • 如果n在计数器c中存在(即nnums1中的一个元素),则将n添加到结果列表ans中。
    • 然后,将计数器cn的计数减1,表示已经找到一个与nums2中的元素相匹配的nums1中的元素。
    • 如果减1后n的计数变为0(意味着nums1中的所有匹配n的元素都已经被使用完),则从计数器c中移除键n。这是为了优化后续查找的性能,因为不再需要查找已经用完的元素。
  4. 返回结果
    • 最后,返回结果列表ans,其中包含了nums1nums2的交集。

代码实现:

from collections import Counter


class Solution:
    def intersect(self, nums1: list[int], nums2: list[int]) -> list[int]:
        if len(nums2) < len(nums1):
            return self.intersect(nums2, nums1)
        ans = []
        c = Counter(nums1)
        for n in nums2:
            if n in c:
                ans.append(n)
                c[n] -= 1
                if c[n] == 0:
                    c.pop(n)
        return ans

相关文章:

  • 高通Camera点亮3——Camera Module
  • 记录此刻:历时两月,初步实现基于FPGA的NVMe SSD固态硬盘存储控制器设计!
  • SpringBoot+Mybatis-Plus实现动态数据源
  • Deepseek-强化学习算法(通俗易懂版)
  • 【带你 langchain 双排系列教程】9.LangChain基于RAG 实现文档问答:从入门到实战
  • inet_pton()函数的概念和使用案例
  • JavaScript作用域和闭包,原理与用途?
  • 面向对象程序设计-实验十一
  • CSS—盒模型(3分钟结合示例精通盒模型)
  • (十七)WebGL中 图像处理的初识
  • docker部署RustDesk自建服务器
  • 数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(一).创建基础表
  • Windows 系统常用快捷键指南
  • Linux 命令大全完整版(14)
  • Linux DMA Engine 基础
  • AI2-THOR环境下实现机器人导航、物体定位与抓取
  • C++经典框架案例(六)
  • CentOS停服后的替代选择:openEuler、Rocky Linux及其他系统的未来展望
  • 《离线唤醒+离线Vosk识别+DeepSeek+离线合成,你的第二大脑》
  • RFID涉密载体柜:智能安全,全程守护,提供智能化的安全管控
  • 哈尔滨建站模板/百度官网认证申请
  • 自助做网站/推广普通话的意义论文
  • 网站建设与管理实验心得/教你如何建立网站
  • 中国专业室内设计公司排名/专业黑帽seo
  • 网站开发的毕业设计题目/开户推广竞价开户
  • 找人做网站怎么知道归属人/怎么制作一个网站首页