3

我有一组点 - 位于网格上。每个点由大小为 3 的一维整数数组指定。边界框由该立方体/长方体的两个对角对角的坐标指定。我在python中编写了以下代码来做到这一点 -

import random as r
list = [[r.randint(-3,3) for j in range(3)] for i in range(90)]
#initialize itmin and itmax
itmin = list[0]
itmax = list[0]
#propagation
for i in range(len(list)):
    for j in range(3):
        itmax[j]=max(itmax[j],list[i][j])
        itmin[j]=min(itmin[j],list[i][j])
print itmax
print itmin

这个的输出——当在 python 上运行时——

[-1, 3, 1]
[-1, 3, 1]  

然而,我本来希望它是

[ 3, 3, 3]
[-3,-3,-3]  

谁能指出我做错了什么?您也可以在线尝试 - http://ideone.com/gNvG6I 如果您觉得问题没有得到适当的充实,请发表评论。

4

1 回答 1

2

itminitmax变量指向同一个列表,所以当你修改一个时,另一个也被修改。

在初始化期间,对初始列表进行浅拷贝,以便每个变量都有自己单独的副本。

itmin = list[0][:]
itmax = list[0][:]

或者,完全跳过循环并使用列表推导获得最大值和最小值。

import random as r
list = [[r.randint(-3,3) for j in range(3)] for i in range(90)]
itmax = [max(point[i] for point in list) for i in range(3)]
itmin = [min(point[i] for point in list) for i in range(3)]
print itmax
print itmin

结果:

[3, 3, 3]
[-3, -3, -3]
于 2013-09-11T14:50:19.760 回答