mathieuviossat/fibonacci-heap
最新稳定版本:v1.0.1
Composer 安装命令:
composer require mathieuviossat/fibonacci-heap
包简介
PHP implementation of the Fibonacci heap
README 文档
README
The Fibonacci heap is a heap data structure with the best amortized running time. It was developed by Michael L. Fredman and Robert E. Tarjan in 1984. The running time of Dijkstra's algorithm can be improved to O(|E| + |V| log |V|) by using a Fibonacci heap.
Installation
composer require mathieuviossat/fibonacci-heap
{
"require": {
"mathieuviossat/fibonacci-heap": "~1.0.0"
}
}
Example
use MathieuViossat\Util\FibonacciHeap; $movies = new FibonacciHeap(); $movies->insert(4, 'The Phantom Menace'); $movies->insert(5, 'Attack of the Clones'); $movies->insert(6, 'Revenge of the Sith'); $movies->insert(1, 'A New Hope'); $movies->insert(2, 'The Empire Strikes Back'); $movies->insert(3, 'Return of the Jedi'); $movies->insert(7, 'The Force Awakens'); while ($movie = $movies->extractMin()) echo $movie->getKey() . ' - ' . $movie->getData() . PHP_EOL;
Methods
minimum() : FibonacciHeapElement
Returns the element with the lowest key, or null if the heap is empty.
Complexity: Θ(1)
insert(int|float $key, mixed $data) : FibonacciHeapElement
Inserts $data with the priority $key in the heap and return the element.
Complexity: Θ(1)
extractMin() : FibonacciHeapElement
Deletes the element with the lowest priority from the heap and return it.
Amortized complexity: O(log n)
decreaseKey(FibonacciHeapElement $element, int|float $key) : void
Replaces $element's key by $key. $key must be lower than the old key.
Amortized complexity: Θ(1)
delete(FibonacciHeapElement $element) : void
Deletes $element from the heap.
Amortized complexity: O(log n)
merge(FibonacciHeap $other) : void
Merges the both heaps. I recommend to only use one of them after that.
Complexity: Θ(1)
isEmpty() : bool
Retuns true if the heap is empty, false otherwise.
Complexity: Θ(1)
size() / count() / count($heap) : int
Retuns the number of elements in the heap.
Complexity: Θ(1)
clear() : void
Removes all elements from the heap.
Complexity: Θ(1)
License
This library is published under The MIT License.
统计信息
- 总下载量: 144
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 5
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-09-03