⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 avltree.h

📁 操作系统中的一个例子
💻 H
字号:
/*
 * Copyright (c) 2000-2008
 * Author: Weiming Zhou
 *
 * Permission to use, copy, modify, distribute and sell this software
 * and its documentation for any purpose is hereby granted without fee,
 * provided that the above copyright notice appear in all copies and
 * that both that copyright notice and this permission notice appear
 * in supporting documentation.  
 */

#ifndef __AVLTREE_H__
#define __AVLTREE_H__

#ifdef __cplusplus
extern "C" {
#endif


typedef BINTREEBASENODE AVLTREENODE;

typedef struct AVLTREE_st {
    AVLTREENODE *pRoot;       /* AVL树的根节点 */
    UINT        uNodeCount;   /* AVL树的节点个数 */
} AVLTREE;

AVLTREE * AVLTree_Create(void);
void      AVLTree_Destroy(AVLTREE *pTree, DESTROYFUNC DestroyFunc);

void    * AVLTree_Find(AVLTREE *pTree, void *pData, COMPAREFUNC CompareFunc);

INT       AVLTreeNode_Insert(AVLTREENODE **ppRootNode, void *pData, 
                             COMPAREFUNC CompareFunc);
INT       AVLTree_Insert(AVLTREE *pTree, void *pData, COMPAREFUNC CompareFunc);

INT       AVLTreeNode_Delete(AVLTREENODE **ppRoot, void *pData, 
                       COMPAREFUNC CompareFunc, DESTROYFUNC DestroyFunc);
INT       AVLTree_Delete(AVLTREE *pTree, void *pData, COMPAREFUNC CompareFunc,
                         DESTROYFUNC DestroyFunc);

#ifdef __cplusplus
}
#endif


#endif /* __AVLTREE_H__ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -