元组对,使用 python 找到最小值

Posted

技术标签:

【中文标题】元组对,使用 python 找到最小值【英文标题】:Tuple pairs, finding minimum using python 【发布时间】:2013-01-25 23:07:41 【问题描述】:

我想找到按给定列排序的元组列表的最小值。例如,我将一些数据排列为 2 元组列表。

data = [ (1, 7.57), (2, 2.1), (3, 1.2), (4, 2.1), (5, 0.01), 
         (6, 0.5), (7, 0.2), (8, 0.6)]

如何仅通过比较元组中的第二个数字来找到数据集的最小值?

data[0][1] = 7.57
data[1][1] = 2.1

分钟(数据)=(5, 0.01)

min( data ) 返回(1, 7.57),我接受它对于索引 0 的最小值是正确的,但我想要索引 1 的最小值。

【问题讨论】:

【参考方案1】:
In [2]: min(data, key = lambda t: t[1])
Out[2]: (5, 0.01)

或:

In [3]: import operator

In [4]: min(data, key=operator.itemgetter(1))
Out[4]: (5, 0.01)

【讨论】:

【参考方案2】:

使用 numpy,您可以使用这些命令来获取列表中项最小的元组:

实现这项工作的要素是 numpy 的高级数组切片和 argsort 功能。

import numpy as np
#create a python list of tuples and convert it to a numpy ndarray of floats
data = np.array([ (1, 7.57), (2, 2.1), (3, 1.2), 
                  (4, 2.1), (5, 0.01), (6, 0.5), (7, 0.2), (8, 0.6)])

print("data is")
print(data)

#Generate sortIndices from second column
sortIndices = np.argsort(data[:,1])

print("sortIndices using index 1 is:" )
print(sortIndices)
print("The column at index 1 is:")
print(data[:,1])
print("Index 1 put into order using column 1")
print(data[sortIndices,1])
print("The tuples put into order using column 1")
print(data[sortIndices,:])
print("The tuple with minimum value at index 1")
print(data[sortIndices[0],:])
print("The tuple with maximum value at index 1")
print(data[sortIndices[-1],:])

哪些打印:

data is
[[ 1.    7.57]
 [ 2.    2.1 ]
 [ 3.    1.2 ]
 [ 4.    2.1 ]
 [ 5.    0.01]
 [ 6.    0.5 ]
 [ 7.    0.2 ]
 [ 8.    0.6 ]]

sortIndices using index 1 is:
[4 6 5 7 2 1 3 0]

The column at index 1 is:
[ 7.57  2.1   1.2   2.1   0.01  0.5   0.2   0.6 ]

Index 1 put into order using column 1
[ 0.01  0.2   0.5   0.6   1.2   2.1   2.1   7.57]

The tuples put into order using column 1
[[ 5.    0.01]
 [ 7.    0.2 ]
 [ 6.    0.5 ]
 [ 8.    0.6 ]
 [ 3.    1.2 ]
 [ 2.    2.1 ]
 [ 4.    2.1 ]
 [ 1.    7.57]]

The tuple with minimum value at index 1
[ 5.    0.01]

The tuple with maximum value at index 1
[ 1.    7.57]

【讨论】:

【参考方案3】:

即使列夫的回答是正确的,我也想添加排序方法,以防有人对第一个 n 最小值感兴趣。 要考虑的一件事是min 操作的运行时间是O(N),其中排序是O(N Log N)

data = [ (1, 7.57), (2, 2.1), (3, 1.2), (4, 2.1), (5, 0.01), (6, 0.5), (7, 0.2), (8, 0.6)]
data.sort(key=lambda x:x[1])
print data

>>> [(5, 0.01), (7, 0.2), (6, 0.5), (8, 0.6), (3, 1.2), (2, 2.1), (4, 2.1), (1, 7.57)]

https://www.ics.uci.edu/~pattis/ICS-33/lectures/complexitypython.txt

【讨论】:

以上是关于元组对,使用 python 找到最小值的主要内容,如果未能解决你的问题,请参考以下文章

如何在带有边界的python优化中找到全局最小值?

如何在有界的python优化中找到全局最小值?

Python Tuple(元组) min()方法

元组列表(字符串,浮点数)与 NaN 如何获得最小值?

从元组列表中返回具有最小 y 值的元组

返回与字典中第三个值最小的元组对应的键