Получите уникальный элемент списка/кортежа с учетом условия в Python
-
21-08-2019 - |
Вопрос
Как мне получить элемент кортежа/списка с учетом условия в 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))
Другие советы
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)
Не связан с StackOverflow