Получите уникальный элемент списка/кортежа с учетом условия в Python

StackOverflow https://stackoverflow.com/questions/862158

Вопрос

Как мне получить элемент кортежа/списка с учетом условия в Python?Это происходит довольно часто, и я ищу питонический способ сделать это в несколько строк.

вот может быть пример:

Рассмотрим кортеж, содержащий координаты двумерных точек, например:

points = [[x1, y1],[x2, y2],[x3, y3], ...]

И я хотел бы получить тот точка, которая минимизирует евклидово расстояние для данной произвольной точки (например, [X, Y], моя точка:его нет в списке!)

def dist(p1, p2):
    return sqrt((p2[0]-p1[0])**2+(p2[1]-p1[1])**2)
pointToCompare2 = [X, Y]

У кого-нибудь есть причудливый лайнер (или нет) для этого?Спасибо!

Это было полезно?

Решение

min(points, key=lambda x: dist(pointToCompare2, x))

min — встроенная функция.

Другие советы

v = [1,3,2,4,7,3,3,4,5,11]

def get_num_uniques(v):
    count = []
    dup = []
tmp = []
for i in v:
    if i not in count:
        count.append(i)
    else:
        dup.append(i)
        count.remove(i)
for j in count:
    if j not in dup:
        tmp.append(j)

return tmp

#Call the function
print get_num_uniques(v)
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top