API参考
载入中...
搜索中...
未找到
avl.h
1/*
2 * This file is part of the openHiTLS project.
3 *
4 * openHiTLS is licensed under the Mulan PSL v2.
5 * You can use this software according to the terms and conditions of the Mulan PSL v2.
6 * You may obtain a copy of Mulan PSL v2 at:
7 *
8 * http://license.coscl.org.cn/MulanPSL2
9 *
10 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
11 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
12 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
13 * See the Mulan PSL v2 for more details.
14 */
15
16#ifndef AVL_H
17#define AVL_H
18
19#include "hitls_build.h"
20#ifdef HITLS_BSL_ERR
21
22#include <stdint.h>
23
24#ifdef __cplusplus
25extern "C" {
26#endif
27
28typedef void *BSL_ElementData;
29
30typedef void (*BSL_AVL_DATA_FREE_FUNC)(BSL_ElementData data);
31
32/* AVL tree node structure */
33typedef struct AvlTree {
34 uint32_t height;
35 uint64_t nodeId;
36 struct AvlTree *rightNode;
37 struct AvlTree *leftNode;
38 BSL_ElementData data;
39} BSL_AvlTree;
40
53BSL_AvlTree *BSL_AVL_MakeLeafNode(BSL_ElementData data);
54
68BSL_AvlTree *BSL_AVL_SearchNode(BSL_AvlTree *root, uint64_t nodeId);
69
83BSL_AvlTree *BSL_AVL_InsertNode(BSL_AvlTree *root, uint64_t nodeId, BSL_AvlTree *node);
84
99BSL_AvlTree *BSL_AVL_DeleteNode(BSL_AvlTree *root, uint64_t nodeId, BSL_AVL_DATA_FREE_FUNC func);
100
112void BSL_AVL_DeleteTree(BSL_AvlTree *root, BSL_AVL_DATA_FREE_FUNC func);
113
114#ifdef __cplusplus
115}
116#endif
117
118#endif /* HITLS_BSL_ERR */
119
120#endif // AVL_H