【发布时间】:2017-01-24 04:47:38
【问题描述】:
在斐波那契堆中,所有操作分析本质上都是摊销的。为什么我们不能像二项式堆那样进行正态分析。
【问题讨论】:
标签: amortized-analysis fibonacci-heap
在斐波那契堆中,所有操作分析本质上都是摊销的。为什么我们不能像二项式堆那样进行正态分析。
【问题讨论】:
标签: amortized-analysis fibonacci-heap
在二项式堆中,每个操作都保证以某种最坏情况的性能运行。插入永远不会超过 O(log n),合并永远不会超过 O(log n + log m) 等。因此,在分析二项式堆的效率时,通常使用 more传统算法分析。
也就是说,二项式堆的几个属性只有在进行摊销分析时才会变得明显。例如,假设堆最初是空的,那么在二项式堆中进行 n 次连续插入的成本是多少?您可以证明,在这种情况下,插入的摊销成本为 O(1),这意味着进行 n 次插入的总成本为 O(n)。从这个意义上说,在传统分析的基础上使用摊销分析可以比最初从更保守的最坏情况分析中获得更多关于数据结构的见解。
从某种意义上说,斐波那契堆最好在摊销的意义上进行分析,因为即使许多操作的最坏情况界限确实不是那么好(例如,删除最小或减少键可能需要时间Θ(n) 在最坏的情况下),在任何一系列操作中,斐波那契堆都具有出色的摊销性能。即使单个删除分钟可能需要 Θ(n) 时间,但一系列 m 删除分钟永远不可能花费超过 Θ(m log n) 时间。
不过,在另一种意义上,斐波那契堆是专门设计为在摊销意义上而不是最坏情况下有效的。它们最初是为了加速 Dijkstra 和 Prim 的算法而发明的,其中重要的是在 n 节点堆上执行 m 个减少键和 n 个删除的总成本,由于这是设计目标,因此设计者没有尝试在最坏的情况下使斐波那契堆高效。
【讨论】: