1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
/*
* Copyright (C) 2003-2024 Paolo Boldi and Sebastiano Vigna
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package PACKAGE;
#if KEY_CLASS_Object
import java.util.Comparator;
#endif
/** A class providing static methods and objects that do useful things with heaps.
*
* <p>The static methods of this class allow to treat arrays as 0-based heaps. They
* are used in the implementation of heap-based queues, but they may be also used
* directly.
*
*/
public final class HEAPS {
private HEAPS() {}
/** Moves the given element down into the heap until it reaches the lowest possible position.
*
* @param heap the heap (starting at 0).
* @param size the number of elements in the heap.
* @param i the index of the element that must be moved down.
* @param c a type-specific comparator, or {@code null} for the natural order.
* @return the new position of the element of index {@code i}.
*/
SUPPRESS_WARNINGS_KEY_UNCHECKED
public static KEY_GENERIC int downHeap(final KEY_GENERIC_TYPE[] heap, final int size, int i, final KEY_COMPARATOR KEY_SUPER_GENERIC c) {
assert i < size;
final KEY_GENERIC_TYPE e = heap[i];
int child;
if (c == null)
while ((child = (i << 1) + 1) < size) {
KEY_GENERIC_TYPE t = heap[child];
final int right = child + 1;
if (right < size && KEY_LESS(heap[right], t)) t = heap[child = right];
if (KEY_LESSEQ(e, t)) break;
heap[i] = t;
i = child;
}
else
while ((child = (i << 1) + 1) < size) {
KEY_GENERIC_TYPE t = heap[child];
final int right = child + 1;
if (right < size && c.compare(heap[right], t) < 0) t = heap[child = right];
if (c.compare(e, t) <= 0) break;
heap[i] = t;
i = child;
}
heap[i] = e;
return i;
}
/** Moves the given element up in the heap until it reaches the highest possible position.
*
* @param heap the heap (starting at 0).
* @param size the number of elements in the heap.
* @param i the index of the element that must be moved up.
* @param c a type-specific comparator, or {@code null} for the natural order.
* @return the new position of the element of index {@code i}.
*/
SUPPRESS_WARNINGS_KEY_UNCHECKED
public static KEY_GENERIC int upHeap(final KEY_GENERIC_TYPE[] heap, final int size, int i, final KEY_COMPARATOR KEY_GENERIC c) {
assert i < size;
final KEY_GENERIC_TYPE e = heap[i];
if (c == null)
while (i != 0) {
final int parent = (i - 1) >>> 1;
final KEY_GENERIC_TYPE t = heap[parent];
if (KEY_LESSEQ(t, e)) break;
heap[i] = t;
i = parent;
}
else
while (i != 0) {
final int parent = (i - 1) >>> 1;
final KEY_GENERIC_TYPE t = heap[parent];
if (c.compare(t, e) <= 0) break;
heap[i] = t;
i = parent;
}
heap[i] = e;
return i;
}
/** Makes an array into a heap.
*
* @param heap the heap (starting at 0).
* @param size the number of elements in the heap.
* @param c a type-specific comparator, or {@code null} for the natural order.
*/
public static KEY_GENERIC void makeHeap(final KEY_GENERIC_TYPE[] heap, final int size, final KEY_COMPARATOR KEY_GENERIC c) {
int i = size >>> 1;
while(i-- != 0) downHeap(heap, size, i, c);
}
}
|