tuyoshi666 2022-04-14 12:51 采纳率: 85.7%
浏览 103
已结题

如何查找最近的坐标点

有一大堆点,知道这些点的x,y坐标(目前不知道用什么储存比较好)
要求,输入一个点,然后在这一大堆点里,查找离输入点最近的点的坐标(使用python)
请问有什么好方法或者算法

  • 写回答

8条回答 默认 最新

  • 歇歇 2022-04-14 21:37
    关注

    使用k维树:

    
     from scipy import spatial
     airports = [(10,10),(20,20),(30,30),(40,40)]# <--点集合
    tree = spatial.KDTree(airports)
     tree.query([(21,21)])# <--要查找的点
    # <--输出结果(距离,airports的数组索引)(array([ 1.41421356]), array([1]))
    

    Numpy有一个有用的函数:norm。

    import numpy as np
    A = [(26, 63), (25, 63), (24, 63), (23, 63), (22, 63), (21, 63), (20, 63), (22, 62), (27, 63)]# <--点集合
    A = np.array(A)
    leftbottom = np.array((0,238))# <--要查找的点
    distances = np.linalg.norm(A-leftbottom, axis=1)
    min_index = np.argmin(distances)
    print(f"最近的点是{A[min_index]}, 距离为{distances[min_index]}")# <--输出结果
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(7条)

报告相同问题?

问题事件

  • 系统已结题 4月25日
  • 已采纳回答 4月17日
  • 创建了问题 4月14日

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?