首頁 >後端開發 >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