alist = [(1,3),(2,5),(2,4),(7,5)]
Мне нужно получить минимальное значение для каждой позиции в кортеже.
Пример Fox: Экзинированный выход alist
min_x = 1
max_x = 7
min_y = 3
max_y = 5
Есть ли какой-нибудь простой способ?
alist = [(1,3),(2,5),(2,4),(7,5)]
Мне нужно получить минимальное значение для каждой позиции в кортеже.
Пример Fox: Экзинированный выход alist
min_x = 1
max_x = 7
min_y = 3
max_y = 5
Есть ли какой-нибудь простой способ?
map(max, zip(*alist))
Это первый разрывает ваш список, затем находит max для каждой позиции кортежа
>>> alist = [(1,3),(2,5),(2,4),(7,5)]
>>> zip(*alist)
[(1, 2, 2, 7), (3, 5, 4, 5)]
>>> map(max, zip(*alist))
[7, 5]
>>> map(min, zip(*alist))
[1, 3]
Это также будет работать для кортежей любой длины в списке.
>>> from operator import itemgetter
>>> alist = [(1,3),(2,5),(2,4),(7,5)]
>>> min(alist)[0], max(alist)[0]
(1, 7)
>>> min(alist, key=itemgetter(1))[1], max(alist, key=itemgetter(1))[1]
(3, 5)
Обобщенный подход будет примерно таким:
alist = [(1,6),(2,5),(2,4),(7,5)]
temp = map(sorted, zip(*alist))
min_x, max_x, min_y, max_y = temp[0][0], temp[0][-1], temp[1][0], temp[1][-1]
Для Python 3 вам потребуется изменить строку, которая создает temp
, чтобы:
temp = tuple(map(sorted, zip(*alist)))
Идею можно абстрагировать в функцию, которая работает как в Python 2, так и в 3:
from __future__ import print_function
try:
from functools import reduce # moved into functools in release 2.6
except ImportError:
pass
# readable version
def minmaxes(seq):
pairs = tuple()
for s in map(sorted, zip(*seq)):
pairs += (s[0], s[-1])
return pairs
# functional version
def minmaxes(seq):
return reduce(tuple.__add__, ((s[0], s[-1]) for s in map(sorted, zip(*seq))))
alist = [(1,6), (2,5), (2,4), (7,5)]
min_x, max_x, min_y, max_y = minmaxes(alist)
print(' '.join(['{},{}']*2).format(*minmaxes(alist))) # 1,7 4,6
triplets = [(1,6,6), (2,5,3), (2,4,9), (7,5,6)]
min_x, max_x, min_y, max_y, min_z, max_z = minmaxes(triplets)
print(' '.join(['{},{}']*3).format(*minmaxes(triplets))) # 1,7 4,6 3,9
По крайней мере, с Python 2.7, "zip" не требуется, поэтому это упрощается до map(max, *data)
(где data
является итератор по кортежам или спискам одинаковой длины).
Другое решение, использующее перечисление и понимание списка
alist = [(1,3),(2,5),(2,4),(7,5)]
for num, k in enumerate(['X', 'Y']):
print 'max_%s' %k, max([i[num] for i in alist])
print 'min_%s' %k, min([i[num] for i in alist])