Files
openGauss-server/src/include/lib/binaryheap.h
2020-06-30 17:38:27 +08:00

67 lines
2.3 KiB
C

/*
* Copyright (c) 2020 Huawei Technologies Co.,Ltd.
*
* openGauss is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
*
* http://license.coscl.org.cn/MulanPSL2
*
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* ---------------------------------------------------------------------------------------
*
* binaryheap.h
* A simple binary heap implementation
*
*
* IDENTIFICATION
* src/include/lib/binaryheap.h
*
* ---------------------------------------------------------------------------------------
*/
#ifndef BINARYHEAP_H
#define BINARYHEAP_H
/*
* For a max-heap, the comparator must return <0 iff a < b, 0 iff a == b,
* and >0 iff a > b. For a min-heap, the conditions are reversed.
*/
typedef int (*binaryheap_comparator)(Datum a, Datum b, void* arg);
/*
* binaryheap
*
* bh_size how many nodes are currently in "nodes"
* bh_space how many nodes can be stored in "nodes"
* bh_has_heap_property no unordered operations since last heap build
* bh_compare comparison function to define the heap property
* bh_arg user data for comparison function
* bh_nodes variable-length array of "space" nodes
*/
typedef struct binaryheap {
int bh_size;
int bh_space;
bool bh_has_heap_property; /* debugging cross-check */
binaryheap_comparator bh_compare;
void* bh_arg;
Datum bh_nodes[FLEXIBLE_ARRAY_MEMBER];
} binaryheap;
extern binaryheap* binaryheap_allocate(int capacity, binaryheap_comparator compare, void* arg);
extern void binaryheap_reset(binaryheap* heap);
extern void binaryheap_free(binaryheap* heap);
extern void binaryheap_add_unordered(binaryheap* heap, Datum d);
extern void binaryheap_build(binaryheap* heap);
extern void binaryheap_add(binaryheap* heap, Datum d);
extern Datum binaryheap_first(binaryheap* heap);
extern Datum binaryheap_remove_first(binaryheap* heap);
extern void binaryheap_replace_first(binaryheap* heap, Datum d);
#define binaryheap_empty(h) ((h)->bh_size == 0)
#endif /* BINARYHEAP_H */