/*- * Copyright 1997, 1999-2003 John-Mark Gurney. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $Id: fibpriv.h,v 1.10 2007/10/09 09:56:46 zerbino Exp $ * */ #ifndef _FIBPRIV_H_ #define _FIBPRIV_H_ #include "def2.h" /* * specific node operations */ struct fibheap_el { int fhe_degree; boolean fhe_mark; FibHeapNode * fhe_p; FibHeapNode * fhe_child; FibHeapNode * fhe_left; FibHeapNode * fhe_right; Coordinate fhe_key; unsigned int fhe_data; }; static FibHeapNode * fhe_newelem ( struct fibheap * ); static void fhe_initelem ( FibHeapNode * ); static void fhe_insertafter ( FibHeapNode * a, FibHeapNode * b ); static inline void fhe_insertbefore ( FibHeapNode * a, FibHeapNode * b ); static FibHeapNode * fhe_remove ( FibHeapNode * a ); /* * global heap operations */ struct fibheap { Coordinate ( *fh_cmp_fnct ) ( unsigned int, unsigned int ); MEM_MANAGER * nodeMemory; IDnum fh_n; IDnum fh_Dl; FibHeapNode ** fh_cons; FibHeapNode * fh_min; FibHeapNode * fh_root; unsigned int fh_neginf; boolean fh_keys: 1; }; static void fh_initheap ( FibHeap * ); static void fh_insertrootlist ( FibHeap *, FibHeapNode * ); static void fh_removerootlist ( FibHeap *, FibHeapNode * ); static void fh_consolidate ( FibHeap * ); static void fh_heaplink ( FibHeap * h, FibHeapNode * y, FibHeapNode * x ); static void fh_cut ( FibHeap *, FibHeapNode *, FibHeapNode * ); static void fh_cascading_cut ( FibHeap *, FibHeapNode * ); static FibHeapNode * fh_extractminel ( FibHeap * ); static void fh_checkcons ( FibHeap * h ); static void fh_destroyheap ( FibHeap * h ); static int fh_compare ( FibHeap * h, FibHeapNode * a, FibHeapNode * b ); static int fh_comparedata ( FibHeap * h, Coordinate key, unsigned int data, FibHeapNode * b ); static void fh_insertel ( FibHeap * h, FibHeapNode * x ); /* * general functions */ static inline IDnum ceillog2 ( IDnum a ); #endif /* _FIBPRIV_H_ */