2

我的程序中有一个函数可以进行拆分和浮动。然后将矩阵传递给主程序。现在我有一个函数可以找到最小值的行和列。在 Martijn Pieters 的帮助下,我得到了最小值,但只有一对。下面给出了输出示例。E 是从 main 传递给此函数的方阵。

值存储在 txt 文件中并在单独的函数中读取,然后将矩阵传递给 main。从他们的矩阵传递给下面的函数。

0 2 8 9
2 4 9 9
4 7 4 8
3 4 8 9

代码:

def closest_pair(e):
    '''for row in range(len(e)):
       for col in range(0,len(row),1):
          minrow = min(e[row])
          mincol = min(e[col])
          return ([minrow], [mincol])'''
       result = min((min((v, c) for c, v in enumerate(row)), r) for r, row in enumerate(e))
       return result[1], result[0][1]

这帮助我找到了行和列的最小值,但是输出是得到这对。同样对于第一个值为 0 的值,0 将不计入,因此如果 (0, 0) 的值为 0,则不算作最小值。话虽如此,例如,如果第 1 行和第 1 列,值是 [2,2] 作为对,并且是唯一比输出 (1,1) 的最小对。

4

1 回答 1

1

你要这个?

>>> def closest_pair(e):
...     remapped = [(e[x][y], (x, y)) for x, row in enumerate(e) for y, col in enumerate(row)]
...     return min(remapped)
... 
>>> a = [[0, 2, 8, 9], [2, 4, 9, 9], [4, 7, 4, 8], [3, 4, 8, 9]]
>>> closest_pair(a)
(0, (0, 0))

或者:

def closest_pair(e):
    return min(
        (e[x][y], (x, y)) 
        for x, row in enumerate(e)
        for y, col in enumerate(row)
    )
于 2013-04-16T17:51:39.950 回答