首頁 >後端開發 >Python教學 >如何在Python中高效計算列表的笛卡爾積?

如何在Python中高效計算列表的笛卡爾積?

Linda Hamilton
Linda Hamilton原創
2024-12-29 12:09:11229瀏覽

How Can I Efficiently Compute the Cartesian Product of Lists in Python?

計算列表的笛卡爾積

從多個列表中獲取笛卡爾積或所有可能的值組合提出了一個常見的挑戰編程。考慮列表列表的範例:

理想輸出:

我們尋求的結果是一個列表,其中包含來自輸入列表:

Pythonic 解決方案: itertools.product

Python 標準函式庫為這項任務提供了一個強大的工具:itertools.product。自 Python 2.6 起,此函數需要輸入序列作為單獨的參數。

或者,您可以明確指定每個序列作為參數:

itertools.product 將傳回產生器對象,將每個組合產生為元組。要獲得所需的列表,您可以迭代生成器並將每個元組轉換為列表(如果需要)。

透過利用 itertools.product,您可以有效地計算多個清單的笛卡爾積,從而避免嵌套的需要循環並確保針對這一常見編程挑戰提供簡潔且可讀的解決方案。

以上是如何在Python中高效計算列表的笛卡爾積?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn