”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何在 Python 中检查一个列表中的元素是否与另一个列表重叠?

如何在 Python 中检查一个列表中的元素是否与另一个列表重叠?

发布于2024-11-08
浏览:525

How Do I Check if Elements from One List Overlap with Another in Python?

在 Python 中测试列表重叠

简介

在 Python 中,确定一个列表中的元素是否存在于另一个列表中对于各种数据操作任务至关重要。本文探讨了测试这种重叠的不同方法,评估其效率并提供最佳实践。

方法

1。生成器表达式

any(i in a for i in b)

此方法迭代一个列表并检查另一个列表中的成员资格,如果匹配则返回 True成立。其时间复杂度为 O(n),其中 n 是较大列表的长度。

2。集合交集

bool(set(a) & set(b))

此方法将两个列表转换为集合并找到它们的交集。如果交集非空,则返回 True。最坏情况的时间复杂度为 O(n m),其中 n 和 m 是列表的长度。

3。混合集交集

a = set(a)
any(i in a for i in b)

此方法仅将一个列表转换为集合,并迭代另一个列表,检查集合成员资格。它避免了中间集合的创建,使其比传统集合交集更快。

4。 Isdisjoint 方法

not set(a).isdisjoint(b)

该方法使用冻结集合的 isdisjoint 方法来确定它们是否有公共元素。如果不存在,结果为 False;

效率比较

最坏情况:

  • 生成器表达式:O(n)
  • 集合交集:O(n m)
  • 混合集合交集:O(n m)
  • 不相交方法:O(1)

大多数情况下,不相交方法是最快的,因为它受益于恒定时间集成员资格检查。

生成器表达式的最佳情况:

  • 当列表的前几个元素时重叠。在这种情况下,生成器表达式可以很快返回 True。

需要考虑的因素:

  • 列表大小
  • 分布列表中的元素
  • 共享元素的频率

最佳实践

  • 对于小型列表(
  • 如果列表结构是可预测的(例如,已排序),则生成器表达式可能会更快。
  • 当列表之间存在显着的大小差异时,请使用 isdisjoint 方法,并以较小的列表作为第一个参数。
  • 对于共享元素很少或没有的列表,isdisjoint 方法通常更有效。
版本声明 本文转载于:1729382599如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符在postgresql中提取最后一行,您可能需要遇到与数据集合中每个不同标识的信息相关的信息。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: id dat...
    编程 发布于2025-05-01
  • 在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    mysql-python安装错误:“ mysql_config找不到”“ 由于缺少MySQL开发库而出现此错误。解决此问题,建议在Ubuntu上使用该分发的存储库。使用以下命令安装Python-MysqldB: sudo apt-get安装python-mysqldb sudo pip in...
    编程 发布于2025-05-01
  • 在PHP中如何高效检测空数组?
    在PHP中如何高效检测空数组?
    在PHP 中检查一个空数组可以通过各种方法在PHP中确定一个空数组。如果需要验证任何数组元素的存在,则PHP的松散键入允许对数组本身进行直接评估:一种更严格的方法涉及使用count()函数: if(count(count($ playerList)=== 0){ //列表为空。 } 对...
    编程 发布于2025-05-01
  • 如何在GO编译器中自定义编译优化?
    如何在GO编译器中自定义编译优化?
    在GO编译器中自定义编译优化 GO中的默认编译过程遵循特定的优化策略。 However, users may need to adjust these optimizations for specific requirements.Optimization Control in Go Compi...
    编程 发布于2025-05-01
  • 在JavaScript中如何获取实际渲染的字体,当CSS字体属性未定义时?
    在JavaScript中如何获取实际渲染的字体,当CSS字体属性未定义时?
    Accessing Actual Rendered Font when Undefined in CSSWhen accessing the font properties of an element, the JavaScript object.style.fontFamily and objec...
    编程 发布于2025-05-01
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-05-01
  • Android如何向PHP服务器发送POST数据?
    Android如何向PHP服务器发送POST数据?
    在android apache httpclient(已弃用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    编程 发布于2025-05-01
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-05-01
  • 为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    The Mystery of "Broken" Two-Phase Template Instantiation in Microsoft Visual C Problem Statement:Users commonly express concerns that Micro...
    编程 发布于2025-05-01
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-05-01
  • 按特定顺序多值排序数据库记录方法
    按特定顺序多值排序数据库记录方法
    按特定顺序的多值排序数据库记录 假设您有一个表,其中包含一个索引键和一个非索引字段 x_field。您需要查找具有特定值的所有记录并返回它们,并根据特定顺序中的多个值对结果进行排序。 例如,如果您有以下表格: idx_field123a124a125a126b127f128b129a130x131...
    编程 发布于2025-05-01
  • 无需学位也能成为网页开发者?
    无需学位也能成为网页开发者?
    是的,您可以在没有学位的情况下成为Web开发人员! 绝对地!在当今的技术世界中,技能至关重要。像Siitecch这样的平台使得在没有正规教育的情况下成为网络开发人员。 这是Siitecch为您提供帮助的方式: 结构化路线图:初学者的逐步学习路径。 实践学习:构建现实世界项目。 需求技能:学习Jav...
    编程 发布于2025-05-01
  • 如何同步迭代并从PHP中的两个等级阵列打印值?
    如何同步迭代并从PHP中的两个等级阵列打印值?
    同步的迭代和打印值来自相同大小的两个数组使用两个数组相等大小的selectbox时,一个包含country代码的数组,另一个包含乡村代码,另一个包含其相应名称的数组,可能会因不当提供了exply for for for the uncore for the forsion for for ytry...
    编程 发布于2025-05-01
  • 浏览器安全限制下,JavaScript如何写入文件?
    浏览器安全限制下,JavaScript如何写入文件?
    使用JavaScript编写数据:综合指南 在文本文件中本地存储数据可以是各种应用程序的有价值技术。尽管JavaScript为操纵浏览器中的数据提供了强大的功能,但直接将数据写入文件的能力从历史上提出了一些挑战。本文探讨了使用JavaScript将数据写入文件的可能性和局限性。浏览器安全限制一个...
    编程 发布于2025-05-01
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-05-01

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3