当使用 [ [ 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