我觉得我在做一些非常愚蠢的事情。也许我只是太累了。
我正在尝试制作一个真值表,它的大小取决于"计数"——表中变量的数量。
table = [[None] * int(pow(2, count))] * count
in_a_row = pow(2, count) / 2
iterator = 0
for i in range(count):
for j in range(int(pow(2, count))):
print(str(i) + ' ' + str(j), end = '')
if iterator < in_a_row:
table[i][j] = 'T'
print(' T')
elif iterator == 2 * in_a_row:
table[i][j] = 'T'
iterator = 0
print(' T')
else:
table[i][j] = 'F'
print(' F')
iterator += 1
print(table)
in_a_row /= 2
iterator = 0
哪个输出:
0 0 T
0 1 T
0 2 F
0 3 F
[['T', 'T', 'F', 'F'], ['T', 'T', 'F', 'F']]
1 0 T
1 1 F
1 2 T
1 3 F
[['T', 'F', 'T', 'F'], ['T', 'F', 'T', 'F']]
您可以看到我在一次迭代中设置的内容在所有"行"中都得到了响应。有人能告诉我这里出了什么问题吗?
我当然期待这个:
[['T', 'T', 'F', 'F'], ['T', 'F', 'T', 'F']]
将第一行更改为:
table = [[None] * int(pow(2, count)) for _ in range(count) ]
毫无疑问,您已经注意到,在第一个版本中,每一行共享对同一列表的引用,而在这个新版本中,我们为每一行创建一个新列表。
由于* count
,它在所有行中都在回显。您实际上是在存储对最初创建的数据的引用count
次mgilson对此进行了修复。