ATLAS Offline Software
Loading...
Searching...
No Matches
binomial-heap.h
Go to the documentation of this file.
1/*
2
3Copyright (c) 2005-2008, Simon Howard
4
5Permission to use, copy, modify, and/or distribute this software
6for any purpose with or without fee is hereby granted, provided
7that the above copyright notice and this permission notice appear
8in all copies.
9
10THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR
14CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
16NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
17CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18
19 */
20
37
38#ifndef ALGORITHM_BINOMIAL_HEAP_H
39#define ALGORITHM_BINOMIAL_HEAP_H
40
41#ifdef __cplusplus
42extern "C" {
43#endif
44
52
62
66
67typedef void *BinomialHeapValue;
68
72
73#define BINOMIAL_HEAP_NULL ((void *) 0)
74
84
86 BinomialHeapValue value2);
87
91
92typedef struct _BinomialHeap BinomialHeap;
93
103
105 BinomialHeapCompareFunc compare_func);
106
112
114
124
126
134
136
143
145
146#ifdef __cplusplus
147}
148#endif
149
150#endif /* #ifndef ALGORITHM_BINOMIAL_HEAP_H */
151
BinomialHeapValue binomial_heap_pop(BinomialHeap *heap)
Remove the first value from a binomial heap.
BinomialHeap * binomial_heap_new(BinomialHeapType heap_type, BinomialHeapCompareFunc compare_func)
Create a new BinomialHeap.
struct _BinomialHeap BinomialHeap
A binomial heap data structure.
int(* BinomialHeapCompareFunc)(BinomialHeapValue value1, BinomialHeapValue value2)
Type of function used to compare values in a binomial heap.
BinomialHeapType
Heap type.
@ BINOMIAL_HEAP_TYPE_MAX
A maximum heap.
@ BINOMIAL_HEAP_TYPE_MIN
A minimum heap.
int binomial_heap_num_entries(BinomialHeap *heap)
Find the number of values stored in a binomial heap.
void * BinomialHeapValue
A value stored in a BinomialHeap.
int binomial_heap_insert(BinomialHeap *heap, BinomialHeapValue value)
Insert a value into a binomial heap.
void binomial_heap_free(BinomialHeap *heap)
Destroy a binomial heap.