A javascript binary heap implementation for Node.js and browser with browserify.
$ npm install bheap
var BinaryHeap = require('bheap')
var heap = new BinaryHeap(function(a, b) {
return a.cash - b.cash;
})
heap.push({ cash: 250, name: 'Valentina' })
heap.push({ cash: 300, name: 'Jano' })
heap.push({ cash: 150, name: 'Fran' )
heap.size // 3
heap.top() // { cash: 300, name: 'Jano' }
heap.pop() // { cash: 300, name: 'Jano' }
heap.size // 2
It creates a new instance of BinaryHeap
based on its parameters.
Time complexity: O(n) such that n === array.length
- Type: Array
- Default: []
Elements that are inserted in binary heap.
- Type: Function
- Default: BinaryHeap.DEFAULT_COMPARATOR
- Returns:
- positive if
a
is great thanb
- negative if
a
is less thanb
- zero if
a
is equal tob
- positive if
It is a function that binary heap uses internally to sort its elements.
It is default comparator if any is passed to constructor and compares two Number
or String
objects. It is static property of BinaryHeap
.
- Type: Number
The size of the binary heap.
Time complexity: O(1)
- Type: Function
- Returns: Element of instance of
BinaryHeap
Gets the top element of the binary heap.
Returns undefined
when the heap is empty.
Time complexity: O(1)
- Type: Function
- Returns: Element of instance of
BinaryHeap
Pops the top element of instance of binary heap.
Returns undefined
when the heap is empty.
Time complexity: O(log(n)) such that n === this.size
- Type: Function
- Returns: Integer
Push the element
at the binary heap and returns its new size.
Time complexity: O(log(n)) such that n === this.size
- Type: Function
Sets a new binary heap based on elements of array
and keeps the same comparator.
Time complexity: O(n) such that n === array.length
I wanted to keep the ECMAScript 6 conventions.
I preferred intuitive API for javascript developers. Thus, I wanted to keep the same behaviour that other data structures as Array which doesn't throw an error when is empty and method pop
is called.
$ npm test
MIT