Junfeng8877 2022-01-17 04:18 采纳率: 100%
浏览 201
已结题

如何将求1NN的改写成求KNN

加载数据库等等

img


img

计算距离

img


这个是求最近的1个值

img


我现在想把上面求1个值改成返回K个最邻值 要如何写?

img

可以麻烦写下代码轮廓么

  • 写回答

11条回答 默认 最新

  • smartisong 2022-01-19 17:01
    关注

    假如计算K个最近邻,在循环里面在计算dist距离时,刚开始K个循环,都要保存下来,从K+1之后,如果距离dist小于前面保存的最大的,就把它替换掉,这样代码的效率会比较高。

    下面是代码, 望采纳!

    
    
        def _predict_item(self, item, K):
            best_labelK = []
            best_distK = []
            n=0
            for i in range(len(train_data)):
                dist = self.metric(train_data[i], item)
                n = n + 1
                if n<=K:
                    best_distK.append(dist)
                    best_labelK.append(self.train_labels[i])
                else:
                    if dist < max(best_distK):
                        update_index = best_distK.index(max(best_distK))
                        best_distK(update_index) = dist
                        best_labelK(update_index) = self.train_labels[i]
        return best_labelK
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(10条)

报告相同问题?

问题事件

  • 系统已结题 1月28日
  • 已采纳回答 1月20日
  • 修改了问题 1月17日
  • 创建了问题 1月17日

悬赏问题

  • ¥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#的问题,如何解决?