首页 >后端开发 >Python教程 >如何在不使用列表推导式的情况下在 Python 中高效创建包含重复元素的列表?

如何在不使用列表推导式的情况下在 Python 中高效创建包含重复元素的列表?

Linda Hamilton
Linda Hamilton原创
2024-12-19 14:21:13985浏览

How Can I Efficiently Create Lists with Repeated Elements in Python Without List Comprehensions?

生成具有重复元素的列表

在 Python 中,可以通过多种方式创建包含相同重复元素的多个列表。本讨论探讨了一种绕过列表推导式的方法。

解决方案:

Python 提供了运算符 * 来复制元素。要创建一个包含 n 个元素 e 的列表,只需使用表达式 [e] * n.

示例:

e = 5
list_of_e = [e] * 10  # [5, 5, 5, 5, 5, 5, 5, 5, 5, 5]

注意:

如果 e 是一个空列表,此方法将创建一个列表,其中 n 个引用指向同一空列表。提供独立的空列表需要不同的方法。

性能评估:

虽然 itertools.repeat() 最初可能看起来更快,但它需要转换为列表来执行比较。运算符 * 直接返回一个列表,从而获得更好的性能:

import timeit
n = 1000000
timeit.timeit('[0] * 10', number=n)  # Faster
timeit.timeit('list(itertools.repeat(0, 10))', number=n)  # Slower

结论:

要创建不带列表推导式的重复元素列表,请利用 * 运算符,提供了简洁高效的解决方案。当需要延迟生成元素时,请考虑 itertools.repeat()。

以上是如何在不使用列表推导式的情况下在 Python 中高效创建包含重复元素的列表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn