在子列表中包含元组的列表中查找最小值



我需要在列表中找到最小的值。该列表包含包含元组的子列表。我需要找到所有元组中最小的值,但它只能包括前3个值。我设法用以下代码实现了,但我希望它看起来更干净。

lst = [[(1, 2, 3, 50)], [(0.2, 0.4, 2, 0.1)], [(0.6, 0.8, 1.2, 0.05)]]
def FitScoreSearch3(fitscores):
fitscores2 = []
for x in fitscores:
for y in x:
for z in y[:3]:
fitscores2.append(z)
return min(fitscores2)

输出应该是0.2。输出不能是0.05。

您的子列表总是只包含一个元组吗?如果是,

def FitScoreSearch3(fitscores):
return min(min(x[0][:3]) for x in fitscores)

如果允许子列表包含几个元组:

def FitScoreSearch3(fitscores):
return min(min(y[:3]) for x in fitscores for y in x)

在这两种情况下,这都会将循环交换为生成器表达式。此外,不是将所有数字收集到一个大列表中并且然后进行min(),而是上面首先在元组(或者更确切地说,元组的前3个元素(上计算min(),之后全局最小值被计算为所有这些"元素"的min();次最小值";。由于这不会创建额外的数据结构,因此速度更快。

min([value for sublist in lst for value in sublist[0][:3]])

在此代码中,lst2包含每个元组的前3个元素的所有值。

lst2 = [ x for sublist in lst for tpl in sublist for x in tpl[:3] ]
print(min(lst2)) # 0.2

您可以执行类似-的操作

def fitScoreSearch3(fitScores):
lst = list(map(lambda x: list(x[0][:3]), fitScores))
minimum = min(list(map(min, lst)))
return minimum

最新更新