| JGL - The Generic Collection Library for Java |
All Packages Class Hierarchy This Package Previous Next Index
Class com.objectspace.jgl.algorithms.Heap
java.lang.Object
|
+----com.objectspace.jgl.algorithms.Heap
- public final class Heap
- extends Object
The Heap class contains generic heap algorithms.
- See Also:
- Heap examples
-
makeHeap(BidirectionalIterator, BidirectionalIterator)
- Arrange a sequence into a heap that is ordered according to the object's hash codes.
-
makeHeap(BidirectionalIterator, BidirectionalIterator, BinaryPredicate)
- Arrange a sequence into a heap that is ordered according to a comparator.
-
popHeap(BidirectionalIterator, BidirectionalIterator)
- Assuming that a sequence is organized as a heap, swap its first and last elements
and then reorganize every element except for the last element to be a heap.
-
popHeap(BidirectionalIterator, BidirectionalIterator, BinaryPredicate)
- Assuming that a sequence is organized as a heap, swap its first and last elements
and then reorganize every element except for the last element to be a heap.
-
pushHeap(BidirectionalIterator, BidirectionalIterator)
- Assuming that a sequence is already organized as a heap, insert the element that
is immediately after the sequence into the heap.
-
pushHeap(BidirectionalIterator, BidirectionalIterator, BinaryPredicate)
- Assuming that a sequence is already organized as a heap, insert the element that
is immediately after the sequence into the heap.
-
sortHeap(BidirectionalIterator, BidirectionalIterator)
- Sort a heap according to the object's hash codes.
-
sortHeap(BidirectionalIterator, BidirectionalIterator, BinaryPredicate)
- Sort a heap according to a comparator.
pushHeap
public static void pushHeap(BidirectionalIterator first,
BidirectionalIterator last)
- Assuming that a sequence is already organized as a heap, insert the element that
is immediately after the sequence into the heap. The elements are organized
according to their hash code. The time complexity is O(log N), where N is the size of
the heap. Space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
pushHeap
public static void pushHeap(BidirectionalIterator first,
BidirectionalIterator last,
BinaryPredicate comparator)
- Assuming that a sequence is already organized as a heap, insert the element that
is immediately after the sequence into the heap. The elements are organized
according to a specified comparator. The time complexity is O(log N), where N is
the size of the heap. Space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- comparator - A binary predicate that returns true if its first operand is "less" than its second operand.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
popHeap
public static void popHeap(BidirectionalIterator first,
BidirectionalIterator last)
- Assuming that a sequence is organized as a heap, swap its first and last elements
and then reorganize every element except for the last element to be a heap. The
elements are organized according to their hash code.
Time complexity is 2*log(last-first) and space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
popHeap
public static void popHeap(BidirectionalIterator first,
BidirectionalIterator last,
BinaryPredicate comparator)
- Assuming that a sequence is organized as a heap, swap its first and last elements
and then reorganize every element except for the last element to be a heap. The
elements are organized according to a specified comparator.
Time complexity is 2*log(last-first) and space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- comparator - A binary predicate that returns true if its first operand is "less" than its second operand.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
makeHeap
public static void makeHeap(BidirectionalIterator first,
BidirectionalIterator last)
- Arrange a sequence into a heap that is ordered according to the object's hash codes.
The time complexity is linear and the space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
makeHeap
public static void makeHeap(BidirectionalIterator first,
BidirectionalIterator last,
BinaryPredicate comparator)
- Arrange a sequence into a heap that is ordered according to a comparator.
The time complexity is linear and the space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- comparator - A binary predicate that returns true if its first operand is "less" than its second operand.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
sortHeap
public static void sortHeap(BidirectionalIterator first,
BidirectionalIterator last)
- Sort a heap according to the object's hash codes.
Time complexity is N*log(N) and the space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the heap.
- last - An iterator positioned immediately after the last element of the heap.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
sortHeap
public static void sortHeap(BidirectionalIterator first,
BidirectionalIterator last,
BinaryPredicate comparator)
- Sort a heap according to a comparator.
Time complexity is N*log(N) and the space complexity is constant.
- Parameters:
- first - An iterator positioned at the first element of the sequence.
- last - An iterator positioned immediately after the last element of the sequence.
- comparator - A binary predicate that returns true if its first operand is "less" than its second operand.
- Throws: IllegalArgumentException
- If the iterators are incompatible.
All Packages Class Hierarchy This Package Previous Next Index