我遇到了这个奇怪的错误,并浪费了2个小时,但无法提出解释
import math
ipd={1:[2,3],2:[1],3:[1],4:[5,6,7],5:[4,6],6:[4,5],7:[4]}
gkeys = [k for k in ipd.iterkeys()]
key_map = {}
for x in range(len(gkeys)):
key_map[x] = gkeys[x]
val = len(gkeys)
#adj matrix...
W = [[0.0]*val]*val
print W
for i in range(len(gkeys)):
for j in range(len(gkeys)):
#if i and j has edge...
if key_map[j] in ipd[key_map[i]]:
deg1 = len(ipd[key_map[j]])
deg2 = len(ipd[key_map[i]])
v = 1.0/math.sqrt(deg1*deg2)
W[i][j] = v
print i,j,deg1,deg2,W[i][j], W[j][i]
这是整个问题
对于i = 3且j = 5,首先W [i] [j]为0.4248 .. 但是对于i = 5,并且j = 3 W [j] [i]给出0.5,这是可能的。
谢谢!
答案 0 :(得分:0)
W = [[0.0]*val]*val
以上为您提供完全相同的列表的val
个副本。
试试这个:
a = [[0] * 4] * 4
print a
a[0][0] = 99
print a
输出:
[[0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]]
[[99, 0, 0, 0], [99, 0, 0, 0], [99, 0, 0, 0], [99, 0, 0, 0]]