巢狀清單索引:解釋Python 基於引用的行為
在Python 中,列表被視為可變的、基於引用的資料結構。此特性在使用巢狀清單時會造成潛在的陷阱,如以下程式碼片段所示:
<code class="python">some_list = 4 * [(4 * [0])]</code>
建立這樣的巢狀清單會建立對相同基礎清單的四個參考。因此,對其中一個引用所做的任何修改都會影響所有其他引用,因為它們具有共同的性質。這種行為在提供的程式碼中很明顯,其中預期輸出:
<code class="python">[0, 0, 0, 0] [0, 1, 1, 1] [0, 1, 1, 1] [0, 1, 1, 1]</code>
與實際輸出衝突:
<code class="python">[0, 1, 1, 1] [0, 1, 1, 1] [0, 1, 1, 1] [0, 1, 1, 1]</code>
為了避免此問題,建議建立一個新清單使用理解方法為每個子列表實例化:
<code class="python">some_list = [(4 * [0]) for _ in range(4)]</code>
這種方法確保每個子列表都是獨立的,解決問題並產生預期的輸出。
以上是為什麼在 Python 中修改巢狀列表元素會影響其所有副本?的詳細內容。更多資訊請關注PHP中文網其他相關文章!