如何在图表上查找n个最近坐标的列表

时间:2014-03-01 21:52:24

标签: python distance min

这是我的问题,我有一个主列表,其中有数据的子列表,一个字符串,告诉列表的类型,x坐标和y坐标。如何使用欧几里德距离函数的键在master_list中找到n个最接近的字符串例如:

my_location = ['a', .59, .59] master_list = [['a', .5, .5], ['b', .3, .2], [a, .4, .4], ['b', .45, .45], ['a', .6, .6], ['b', .55, .55]] input: function(3, my_location, master_list) output: [['a', .6, .6], ['b', .55, .55], ['a', .5, .5]]

该函数的键应如下所示:key = sqrt((x1-x2)* 2 +(y1 - y2) * 2

1 个答案:

答案 0 :(得分:2)

from math import sqrt

location = ['a', .59, .59]
master_list = [['a', .5, .5],
               ['b', .3, .2],
               ['a', .4, .4],
               ['b', .45, .45],
               ['a', .6, .6],
               ['b', .55, .55]]


def get_neighbours(distance, location, locations):
    neighbours = []    
    for loc in locations:
        if sqrt((location[1] - loc[1])**2 + (location[2] - loc[2])**2) < distance:
            neighbours.append(loc)
    return neighbours

print get_neighbours(3, location, master_list)

如果你想要快速,你应该看看2D碰撞检测的东西.. Axis Alligned Bounding Boxes,Quadtrees,Sweep和Prune等..

你可以做一个快速测试来消除很远的节点,如果你有很多节点可能值得这样做(否则保持代码简单并且不要过早优化):

if abs(location[1] - loc[1]) > d:
   continue

if abs(location[2] - loc[2]) > d:
   continue

如果这是家庭作业,那么你自己也没有帮助别人为你做这件事:)