V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
begeekmyfriend
V2EX  ›  程序员

kNN 算法的 kd 树实现( C 源码)

  •  1
     
  •   begeekmyfriend ·
    begeekmyfriend · 2017-02-22 19:14:56 +08:00 · 2142 次点击
    这是一个创建于 2833 天前的主题,其中的信息可能已经有所发展或是发生改变。
    https://github.com/begeekmyfriend/kdtree

    特点:绝对平衡,搜索极快,代价是动态性差,每次增删后需要重建。

    实现是对增删进行缓存,直到重建才映射到实际数据结构中去。重建会对每个维度分量进行快速排序,以确保每个树节点都是取中值,实现了绝对平衡,也即最小高度,最大限度降低搜索比较次数,杜绝最差情况发生。

    注意,排序只是对数据样本的索引进行移动,数据本身插入时只拷贝一次,数据样本集中缓存有利于 cache 命中。

    有兴趣欢迎探讨。
    5 条回复    2017-04-20 18:10:58 +08:00
    y8y
        1
    y8y  
       2017-02-22 19:17:20 +08:00
    我是第一个赞的,楼主的 C 代码看起来很舒服。
    zgqq
        2
    zgqq  
       2017-02-22 19:30:21 +08:00 via Android
    大佬
    franklinyu
        3
    franklinyu  
       2017-02-23 01:47:55 +08:00
    除了「 for(; ;)」和「 8 個空格縮進」屬於口味不同以外,樓主的代碼簡直是一股清流……
    congeec
        4
    congeec  
       2017-02-23 06:47:21 +08:00 via iPhone
    正规军
    wujunze
        5
    wujunze  
       2017-04-20 18:10:58 +08:00
    👍
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2682 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 15:34 · PVG 23:34 · LAX 07:34 · JFK 10:34
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.