All Downloads are FREE. Search and download functionalities are using the official Maven repository.

drv.Heaps.drv Maven / Gradle / Ivy

Go to download

fastutil extends the Java Collections Framework by providing type-specific maps, sets, lists and priority queues with a small memory footprint and fast access and insertion; provides also big (64-bit) arrays, sets and lists, and fast, practical I/O classes for binary and text files.

There is a newer version: 8.5.15
Show newest version
/*		 
 * Copyright (C) 2003-2016 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.
 *
 * 

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 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 null for the natural order. * @return the new position of the element of index 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 null for the natural order. * @return the new position of the element of index 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 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 ); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy