0

0

Python怎么找两数组交集_set()操作与双指针算法对比

P粉602998670

P粉602998670

发布时间:2026-03-11 18:57:12

|

968人浏览过

|

来源于php中文网

原创

set求交集在多数场景下最快,时间复杂度约o(n+m),但会丢失顺序与重复信息;双指针适合已排序数组,保序且可控重复,空间复杂度o(1)。

python怎么找两数组交集_set()操作与双指针算法对比

set() 求交集快不快?看场景

绝大多数情况下,set(nums1) & set(nums2) 是最简、最快的选择——前提是不关心顺序、不保留重复元素、且数组不是超大(比如上亿元素)。

Python 的 set 底层是哈希表,求交集时间复杂度接近 O(min(len(nums1), len(nums2))),但建集合本身要遍历一次数组,总开销约 O(n + m)。内存会多占一份去重后的副本。

常见错误现象:list(set(nums1) & set(nums2)) 返回结果顺序不定;如果原数组有重复值(如 [1,1,2][1,2,2]),交集只留一个 1 和一个 2,丢失频次信息。

  • 需要去重 + 无视顺序 → 直接用 set 最省事
  • 输入已排序,且想保持升序输出 → set 会打乱顺序,不如双指针
  • 内存敏感(如嵌入式或流式处理)→ set 额外占内存,慎用

双指针法适合什么情况?

当两个数组都已排序,且你要求结果也有序、或需保留重复逻辑(比如“每个元素在交集中出现次数 = 两数组中该元素最小出现次数”),双指针是更精准的解法。

立即学习Python免费学习笔记(深入)”;

它不依赖哈希,空间复杂度仅 O(1)(不算输出列表),遍历过程天然保序,还能灵活控制重复行为。

银河易创
银河易创

一站式AIGC创作平台,集成GPT-3.5、GPT-4、文心一言等对话模型、Midjourney、DallE等绘画工具、AI音乐、AI视频和AI PPT等功能!

下载

典型使用场景:LeetCode 350 “两个数组的交集 II”,要求返回带重复的交集;或者你在处理数据库分页结果、时间序列对齐等已排好序的数据流。

  • 两数组必须事先升序排列,否则指针移动会漏匹配
  • 边界判断容易错:任一指针越界就得停,别写成 while i 后还继续访问 <code>nums1[i]
  • 重复处理逻辑要明确:遇到相等时 append 后,两个指针都进一;不等时只动小数那边的指针

set.intersection()& 有区别吗?

没实质区别。set1 & set2 是运算符语法糖,底层调用的就是 set1.intersection(set2)。但注意:后者支持多个参数,比如 set1.intersection(set2, set3, set4),而 & 只能两两连用(set1 & set2 & set3 也行,但本质还是左结合)。

性能上几乎无差异,Cython 层都走同一套逻辑。不过 intersection() 支持传入任意可迭代对象(比如 set1.intersection([1,2,3])),而 & 要求右边也得是 set 类型,否则报 TypeError: unsupported operand type(s)

  • 想一行写多个集合交集 → 用 .intersection() 更直白
  • 右边可能是 list/tuple 且不想显式转 set → 只能用 .intersection()
  • 做类型检查或 lint 报警时,有些工具对运算符重载提示较弱,用方法名更易追踪

实际选哪个?关键看这三点

别纠结“哪个更高级”,就盯住输入特征和输出需求:

  • 输入是否已排序?是 → 优先双指针;否 → set 省心
  • 是否要保留重复?是 → 双指针可精确控频次;set 天然去重,绕不开
  • 内存 or 速度优先?大数据量且内存紧 → 双指针;中小数据且写快为主 → set

最容易被忽略的是:很多人直接对未排序数组硬套双指针,结果逻辑全错;或者在需要频次的题里盲目用 set,提交后发现用例过不了。顺序和重复性这两个约束,比“哪个快”重要得多。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

241

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

148

2025.10.17

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.09.25

Go语言实现运算符重载有哪些方法
Go语言实现运算符重载有哪些方法

Go语言不支持运算符重载,但可以通过一些方法来模拟运算符重载的效果。使用函数重载来模拟运算符重载,可以为不同的类型定义不同的函数,以实现类似运算符重载的效果,通过函数重载,可以为不同的类型实现不同的操作。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

196

2024.02.23

Go语言实现运算符重载有哪些方法
Go语言实现运算符重载有哪些方法

Go语言不支持运算符重载,但可以通过一些方法来模拟运算符重载的效果。使用函数重载来模拟运算符重载,可以为不同的类型定义不同的函数,以实现类似运算符重载的效果,通过函数重载,可以为不同的类型实现不同的操作。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

196

2024.02.23

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

348

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1080

2023.11.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号