为什么追加会覆盖列表?

2022-03-25 00:00:00 python python-3.6

问题描述

我在尝试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]]

相关文章