函数参数:即使按值传递,也会修改原始变量

时间:2015-01-16 23:46:16

标签: python python-3.x parameter-passing pass-by-reference pass-by-value

我有一个基本上使用dijkstra算法在图中找到距离的函数

def getDistances(q,start):

print(q)

q[start][0] = 0
queue = [start]
while len(queue):


    m = []


    mMin = queue[0]
    m = q[mMin][2]
    queue.remove(mMin)


    for x in q[m][3]:

        if q[x][1] == 0:

            if not x in queue:
                queue.append(x)

            if q[x][0] > q[m][0] + 1:

                q[x][0] = q[m][0] + 1

    q[m][1] = 1

return [x[0] for x in q]

但它完美无缺。但是,我必须多次调用此函数。并且“q”参数保持不变。这是调用:

for ex in exits:
    dist = getDistances(list(qt),ex)
    distances.append([ex,dist])

“qt”本身是一个包含许多不同参数的列表。在这种情况下,我认为它不像问题本身那么重要。

问题 如果在函数内部修改了“q”变量,则修改“qt”变量。正如您在调用中看到的那样,我尝试使用list(qt)按值而不是通过引用传递变量。 感谢您提前提供任何帮助!

2 个答案:

答案 0 :(得分:2)

您必须创建deepcopy

from copy import deepcopy

dist = getDistances(deepcopy(qt), ex)

答案 1 :(得分:0)

您还需要复制列表中的元素。例如:q[x][0] = q[m][0] + 1修改它们。做:

dist = getDistances(list(list(e) for e in qt), ex)