python的列表的remove()方法、判断if xxx in xx条件比较耗时问题

本文涉及的产品
视觉智能开放平台,图像资源包5000点
视觉智能开放平台,视频资源包5000点
视觉智能开放平台,分割抠图1万点
简介: python的列表的remove()方法、判断if xxx in xx条件比较耗时问题

最近在coding的时候,写的代码中只有一层循环,却很耗时不明觉厉。不知道是哪里出了问题,于是我就在每一行代码中都打印一下耗时,最终发现了这个罪魁祸首。这里我只说明两个我遇到耗时的场景,当然还有很多其他的方法可能也是一样的,这里只是提供问题的思路!


说明:

这里比较耗时,是我在外层使用了循环,在循环内部调用了列表的remove()方法、使用了if xxx in xx判断等类似操作!

1 python列表的remove方法比较耗时原因

1、例如,下面的伪代码

  • 首先是循环
  • 然后通过remove删除字典对应value列表中的一个元素

就是在remove删除列表元素的过程,其实是相当对这个value列表进行循环,当循环到要删除的元素后,循环停止!

因此这段代码的时间复杂度就是$<=O^2$,几乎就等价于两层for循环,因此当第一层循环有80W,第二层有1w,这个循环就已经非常耗时了!

data = {
   'a': [], 'b': [], ...}
for key, value in data.items():
    value.remove('xxx')

2、判断if xxx in xx条件比较耗时问题

1、例如,如下的伪代码

data = {
   'a': [], 'b': [], ...}
for key, value in data.items():
    if xxx in xx

如果判断元素xxx是否在xx中,加入这个xx是一个列表,其实在判断的过程中,也是类似先对列表进行循环,让元素xxx和列表中的xx每个元素做对比,如果提前比对到就停止循环,和上面的remove()方法都是类似的,因此也会比较耗时!

因此,在写代码的时候一定想办法让代码更简洁,同时保证高效性

目录
相关文章
|
1天前
|
数据处理 开发者 Python
探索Python中的列表推导式
在Python编程中,列表推导式(List Comprehensions)是一种简洁而强大的工具,允许开发者用一行代码生成整个列表。本文将深入探讨列表推导式的用法、优势以及在实际项目中的应用。通过具体的示例,我们将展示如何利用列表推导式简化代码,提升可读性和执行效率。无论你是编程新手还是经验丰富的开发者,都能从本文中获得有价值的见解和技巧。
|
5天前
|
C语言 Python
深入理解并实践Python中的列表推导式
深入理解并实践Python中的列表推导式
9 1
|
5天前
|
Python
Python中几种lambda排序方法
【9月更文挑战第7天】在Python中,`lambda`表达式常用于配合排序函数,实现灵活的数据排序。对于基本列表,可以直接使用`sorted()`进行升序或降序排序;处理复杂对象如字典列表时,通过`lambda`指定键值进行排序;同样地,`lambda`也适用于根据元组的不同位置元素来进行排序。
|
16天前
|
存储 缓存 C语言
|
14天前
|
Python
探索Python中的列表推导式:简洁与效率的融合
【8月更文挑战第31天】在编程的世界里,我们总是在寻找使代码更简洁、更高效的方法。Python语言提供了一种强大的工具——列表推导式,它允许我们在一行代码中生成列表,既提高了代码的可读性,也提升了执行效率。本文将带你了解列表推导式的基本概念,通过示例展示其使用场景,并探讨如何优雅地运用这一特性来简化你的Python代码。
|
14天前
|
数据处理 开发者 Python
探索Python中的列表推导式:一种简洁而强大的工具
【8月更文挑战第31天】在Python编程中,列表推导式是一种高效且优雅的构建列表的方法。本文将通过实际代码示例深入探讨列表推导式的不同形式及其使用场景,旨在帮助读者更好地理解和运用这一强大工具。
|
14天前
|
存储 Python
探索Python中的列表推导式
【8月更文挑战第31天】本文将深入探讨Python编程中的一个强大功能——列表推导式。我们将了解其基本概念、用法,以及如何利用这一特性简化代码和提高运行效率。通过实际的代码示例,我们会发现列表推导式不仅仅是一种语法糖,而是一种可以大幅提升代码可读性和性能的工具。
|
14天前
|
UED Python
探索Python中的魔法方法:打造自定义字符串表示
【8月更文挑战第31天】在Python的世界里,魔法方法是那些以双下划线开头和结尾的特殊方法,它们为类提供了丰富的功能。本文将带你走进这些魔法方法的背后,特别是__str__和__repr__,揭示如何通过它们来定制我们的对象在被打印或转换为字符串时的外观。我们将从基础用法开始,逐步深入到高级技巧,包括继承与重写,最终实现一个优雅的字符串表示方案。准备好了吗?让我们开始这段代码之旅吧!
|
15天前
|
存储 C语言 Python
|
15天前
|
数据处理 开发者 Python
探索Python中的列表推导式:简洁与高效的融合
【8月更文挑战第30天】在编程的世界里,代码的优雅和效率往往如同天平的两端,难以兼得。然而,Python语言中的列表推导式(List Comprehension)却巧妙地实现了这两者的平衡。它以简明扼要的语法,将循环和条件判断融入一行代码之中,既提升了代码的可读性,又不失执行的效率。本文将深入探讨列表推导式的魅力所在,并通过对比分析,揭示其背后的逻辑结构,带你领略这一Python独到特性的风采。