當使用 [ [ None ] *n ] *n 方法創建時,會使子列表都指向同一列表
>>> t = [[]] * 5
>>> t
[[], [], [], [], []]
>>> t[0].append(5) #改變一子列表導致其他均被改變
>>> t
[[5], [5], [5], [5], [5]]
為了避免此類情況
t = list([None]*n for i in range(n))
or
t = [[None]*n for i in range(n)]
使用generator使每個子列表都不同
PS:
當列表在二維 [ [ ] ] 或以上時,
必須使用 copy.deepcopy() 來進行列表的復制
否則原列表和復制列表的子列表會指向同一目標
即 id(originalList[0]) == id(copyList[0])
Reference:
https://blog.csdn.net/Strive_For_Future/article/details/83417693