-1

在 python 2.7 中工作。

我确信代码有点笨拙,但我会尽可能简单地解释它。

我有两个清单:

T = [[1,0], [1,0], [0,5]]
S = [[1], [3], [2]]

我需要将 B 中的对应值添加到 T 中对应列表的末尾,所以使用 zip 将它们放在一起。

然后,我计算从第三个列表中减去每个列表的第一个值的结果,并使用另一个 zip 函数附加该值。

所以当我运行我的函数时,T 变量现在看起来像 [[1,0,1,0], [1,0,3,-2], [0,5,2,-2]]。

然后我有一系列 if 语句,如果某些值高于或低于其他值,则列表返回胜利、失败或平局。

我想多次模拟我的函数(starterTrans)的结果。问题是当我使用时:

def MonteCarlo(T, S, x):
    for i in range(0, x):
        starterTrans(T, S)

对于每次模拟,我都会得到不同版本的 T。因此,第一次通过模拟时,T 在每个列表中都有适当数量的元素(四个),但在每次运行之后,添加的变量越来越多。

无论我想使用多少次,我都需要一种方法将 T 锁定到它原来的四个变量。我正在努力寻找一种方法来做到这一点。有任何想法吗?

我知道我的代码很复杂,但如果它可以帮助任何人按照我的尝试来描述我的问题:

def starterTrans(team, starter):
    wins = 0
    losses = 0
    nd = 0
    random.shuffle(team)
    for t, s in zip(team, starter):
        t.extend(s)
    score_add(team, exit_score(team, starter))
    length = len(starter)
    for i in range(0, length):
        if team[i][4] > 0 and (team[i][1] > -team[i][4]) and team[i][2] >= 5:
            wins += 1
        elif team[i][4] < 0 and (team[i][1] <= -team[i][4]):
            losses += 1
        elif (team[i][4] <= 0 and team[i][1] >= -team[i][4]):
            nd += 1
    return wins, losses, nd

def score_add(team, exit_scores):
    for t, e in zip(team, exit_scores):
        t.append(e)
    return team

def exit_score(team, starter):
    exit_scores = []
    length = len(starter)
    for i in range(0, length):
        score = team[i][0]-team[i][3]
        exit_scores.append(score)
    return exit_scores

def MonteCarlo(team, starter, x):
    for i in range(0, x):
        starterTrans(team, starter)

谢谢你的帮助。

4

2 回答 2

1

我认为你只需要改变这个:

def MonteCarlo(T, S, x):
    for i in range(0, x):
        starterTrans(T, S)

对此:

def MonteCarlo(T, S, x):
    for i in range(0, x):
        starterTrans(T[:], S)

T这将传递tostarterTrans(..)而不是原始列表的副本。如果您正在编辑其中的元素,TstarterTrans(..)将无济于事。在这里你需要一个深拷贝。在这里看看浅拷贝和深拷贝之间的区别:深拷贝和浅拷贝有什么区别?.

于 2011-11-04T22:31:01.923 回答
0

将最后一行更改为starterTrans(team[:], starter). 那将传递一份team副本,而原封不动。

于 2011-11-04T22:05:37.753 回答