我在编写以下代码时遇到问题:

D = [
        [0,3,8,999,-4],
        [999,0,999,1,7],
        [999,4,0,999,999],
        [2,999,-5,0,999],
        [999,999,999,6,0]
    ]

def FloydWarshall (W):
    matrices = [W[:]]
    pred = [W[:]]

    print (matrices is pred)
    print (pred is matrices)
    print (pred is W)
    print (matrices is W)

    for i in range(0,len(pred[0])):
        for j in range(len(pred[0][i])):

            if pred[0][i][j] != 999 and pred[0][i][j] != 0:
                pred[0][i][j] = i +1
            else:
                pred[0][i][j] = False 

    return (matrices,pred)
FloydWarshall(D)

返回的值是完全相同的矩阵,这是为什么呢? 打印语句说它们不是指向内存中相同位置的指针,对吗?

===============>>#1 票数:5 已采纳

您只是对嵌套列表进行了浅表复制,因此对它们进行突变仍然会影响两个矩阵。 您可能要使用copy.deepcopy

  ask by Lilluda 5 translate from so

未解决问题?本站智能推荐: