为什么追加会覆盖列表?
问题描述
我在尝试HackerRank的一些问题时遇到了这个问题 https://www.hackerrank.com/challenges/list-comprehensions/problem我尝试了此解决方案
if __name__ == '__main__':
x = int(input())
y = int(input())
z = int(input())
n = int(input())
L = []
SL = []
for i in range(0, x + 1):
for j in range(0, y + 1):
for k in range(0, z + 1):
if i + j + k != n:
SL[:] = []
SL.append(i)
SL.append(j)
SL.append(k)
print(SL)
L.append(SL)
print(L)
虽然SL有正确的解决方案,但由于某些原因,我不能将SL附加到主列表L,而且很明显,L。append(SL)每次执行时都会覆盖列表L,因为它打印SL的最后一个值。 为什么会这样呢? 我尝试使用Extended,但是没有将其创建为列表列表,而是将其创建为整数列表。 编辑:谢谢大家的解释!
解决方案
您的代码确实不能工作,这是由于SL[:] = []
行:它更改了SL
引用的列表的内容。通过这样做,您可以更改L
的所有元素,因为您总是在循环中将SL
引用的列表追加到L
。替换为SL = []
将解决此问题,因为在这种情况下,您将创建一个新列表,而不覆盖以前的列表。
它可以是固定的,也可以更具可读性,更易于调试(如果需要),建议如下:
L = []
for i in range(0, x + 1):
for j in range(0, y + 1):
for k in range(0, z + 1):
if i + j != n and i + k != n and k + j != n and i + j + k != n:
L.append([i, j, k])
print(L)
当x=1,y=2,z=3,n=4时:输出如下:
[[0, 0, 0], [0, 0, 1], [0, 0, 2], [0, 0, 3], [0, 1, 0], [0, 1, 1], [0, 1, 2], [0, 2, 0],
[0, 2, 1], [0, 2, 3], [1, 0, 0], [1, 0, 1], [1, 0, 2], [1, 1, 0], [1, 1, 1], [1, 2, 0]]
相关文章