- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在以广度优先的方式在数组表示中实现动态kD-Tree(将节点存储在 std::vector 中)。每个i
-th 非叶节点在 (i<<1)+1
处有一个左子节点和一个合适的 child 在(i<<1)+2
.它将支持点的增量插入和点的集合。但是,我在确定增量预分配空间所需的可能节点数时遇到了问题。
我找到了 formula on the web ,这似乎是错误的:
N = min(m − 1, 2n − ½m − 1),
where m is the smallest power of 2 greater than or equal to n, the number of points.
我对公式的实现如下:
size_t required(size_t n)
{
size_t m = nextPowerOf2(n);
return min(m - 1, (n<<1) - (m>>1) - 1);
}
函数 nextPowerOf2 返回最大或等于 n 的 2 的幂
如有任何帮助,我们将不胜感激。
最佳答案
kd-tree的每个节点将空间分成两个空间。因此,kd 树中的节点数取决于您如何执行此划分:
1)如果你在空间的中点划分它们(也就是说,如果空间是从x1到x2,你用x3=(x1+x2)/2线划分空间),那么:i) 每个点将被分配到它自己的节点,并且ii) 每个中间节点都是空的。
在这种情况下,节点的数量将取决于点的坐标有多大。如果坐标以 |X| 为界,则 kd-tree 中的节点总数应略小于 log |X| * n(更准确地说,大约 log |X| * n - n log n + 2n)在最坏的情况下。要看到这一点,请考虑以下添加点的方式:添加多个集合,每个集合有两个随机分布的非常接近的点。对于每一对点,树将需要连续划分空间日志 |X|次,如果记录 |X|明显大于 log n,创建 log |X|过程中的中间节点。
2) 如果用一个点作为分界线来划分它们,那么每个节点(包括中间节点)都会包含一个点。因此,节点总数就是 n。但是,请注意,如果点不是以随机顺序给出(例如,如果点按 X 的升序给出,则树的深度将为O(n)。为了比较,(1)中树的深度至多为O(log |X|))。
关于c++ - 预测 kD 树中所需的预分配节点数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31123012/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!