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

📄 rbtree.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 __RBTREE_H__
#define __RBTREE_H__

#ifdef __cplusplus
extern "C" {
#endif

#define     RBTREE_COLOR_RED    0
#define     RBTREE_COLOR_BLACK  1

typedef  BINTREEBASENODE  RBTREENODE;

typedef struct RBTREE_st {
    RBTREENODE *pRoot;
    RBTREENODE *pCursor;
    UINT        uNodeCount;
} RBTREE;


typedef RBTREENODE *(*RBTREENODECREATEFUNC)( void *pData);

RBTREE *RBTree_Create(void);
void     RBTree_Destroy(RBTREE *pBinTree, DESTROYFUNC DestroyFunc);

INT      RBTree_Insert(RBTREE *pBinTree, void *pData, COMPAREFUNC CompareFunc);
INT      RBTree_Delete(RBTREE *pTree, void *pData, 
                       COMPAREFUNC CompareFunc,
                       DESTROYFUNC DestroyFunc);

void    *RBTree_Find(RBTREE *pBinTree, void *pData, COMPAREFUNC CompareFunc);

INT RBTree_Inter_Insert(RBTREE *pTree, RBTREENODE *pNode, COMPAREFUNC CompareFunc);

void RBTree_EnumBegin(RBTREE *pTree);
void * RBTree_EnumNext(RBTREE *pTree);

void *RBTree_GetMinium(RBTREE *pTree, RBTREENODE *pNode);
void *RBTree_GetMaxium(RBTREE *pTree, RBTREENODE *pNode);

#ifdef __cplusplus
}
#endif


#endif /* __RBTREE_H__ */

⌨️ 快捷键说明

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