在python3.5中使用附加法时出现了一些问题。给出了代码。
# generate boson basis in lexicographic order
def boson_basis(L,N):
basis=[]
state=[0 for i in range(1,L+1)]
pos=0
# initialize the state to |N,0,...,0>
state[0]=N
basis.append(state)
# find the first non-zero position in reverse order
while state[L-1]<N:
for i in range(-2,-L-1,-1):
if state[i]>0:
pos=L+i
break
sum=0
for i in range(0,pos):
sum=sum+state[i]
state[pos]=state[pos]-1
state[pos+1]=N-sum-state[pos]
basis.append(state)
return basis
result=boson_basis(3,3)
预期的结果应该是[[3,0,0],[2,1,0],...,[0,0,3]]
,但是这段代码生成错误的结果,所有元素都与最后一个相同,即[[0,0,3],...,[0,0,3]]
。我使用pdb来调试它,我发现一旦修改了state
,添加到basis
中的前一个state
也会同时发生变化。这意味着append
自动使用deepcopy
,这超出了我的理解。事实上,如果我们显式地使用basis(state.copy())
,这个错误是可以修复的。
另一方面,下面的简单代码显示在使用append
时没有错误
x=3
b=[]
b.append(x)
x=x+2
在x
更改为x=5
后,b
保持不变的b=[3]
。这确实令我困惑,似乎与前一个例子相矛盾。
发布于 2016-11-04 07:01:44
正如评论中所揭示的,在append
操作中没有任何副本。因此,您必须亲自显式地处理这一问题,例如通过替换
basis.append(state)
使用
basis.append(state[:])
使用:
的切片操作创建了state
的副本。注意:它不会复制列表元素--只要您只保留简单的数字,而不是列表中的对象,就可以了。
https://stackoverflow.com/questions/40425554
复制