2

我已经在 J​​ava 中研究斐波那契堆实现大约一周了。它是基于 CLRS 书的实现。

我想看看与 Java 的默认 PriorityQueue 相比,在我正在处理的副项目中使用它是否会获得任何性能提升。[Java 中的默认实现是基于数组的,因此更加本地化。尽管复杂度更高,但它仍可能优于 F-Heap]。

我的问题似乎源于删除 min 元素后堆的合并部分。我不断收到 arrayindexoutofboundsexceptions 抛出。特别是在while循环中,当它合并具有相同度数的所有节点时。它超出了 D() 函数设置的范围。

所以要么我的 D() 函数是错误的,我不认为它是错误的,要么是发生了其他事情。最有可能与副作用有关。

代码位于此处。我一直在尝试调试这个大约一周,现在很幸运。我错过了一些明显的东西吗?

4

1 回答 1

1

您需要检查分析,因为我不确定节点度的上限是否不应该是地板。在您的 D 函数中,您对 int 的强制转换正在截断小数部分。将此更改为舍入似乎可以清除索引越界错误。

不过似乎还有一个额外的问题。我没有追查什么条件,但子列表最终可能没有前哨集。这会在子列表中循环时导致 removeMin 中的无限循环,因为它们是循环的。

于 2009-08-31T01:19:14.750 回答