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

📄 bintree.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 __BINTREE_H__
#define __BINTREE_H__

#ifdef __cplusplus
extern "C" {
#endif

typedef struct BINTREENODE_st {
    struct BINTREENODE_st *pLeft;
    struct BINTREENODE_st *pRight;
    void *pData;
} BINTREENODE;

typedef struct BINTREEBASENODE_st {
    struct BINTREEBASENODE_st *pLeft;
    struct BINTREEBASENODE_st *pRight;
    struct BINTREEBASENODE_st *pParent;
    INT                        nMagic;
    void                      *pData;
} BINTREEBASENODE;


typedef struct BINTREE_st {
    BINTREEBASENODE *pRoot;
    UINT        uNodeCount;
} BINTREE;

BINTREE *BinTree_Create(void);
void BinTreeBaseNode_Destroy(BINTREEBASENODE *pBINTREEBASENODE, 
                             DESTROYFUNC DestroyFunc);
void    BinTree_Destroy(BINTREE *pBinTree, DESTROYFUNC DestroyFunc);

INT     BinTree_Add(BINTREE *pBinTree, void *pData, COMPAREFUNC CompareFunc);
void *BinTree_Find(BINTREEBASENODE *pRoot, void *pData, COMPAREFUNC CompareFunc);
BINTREEBASENODE *BinTree_FindNode(BINTREEBASENODE *pRoot, void *pData, COMPAREFUNC CompareFunc);
INT     BinTree_AddLeft(BINTREE *pBinTree, void *pTagNodeData, 
                    void *pData, COMPAREFUNC CompareFunc);
INT     BinTree_AddRight(BINTREE *pBinTree, void *pTagNodeData, 
                    void *pData, COMPAREFUNC CompareFunc);
INT     BinTree_Delete(BINTREE *pBinTree, void *pData, 
                       COMPAREFUNC CompareFunc,
                       DESTROYFUNC DestroyFunc);

void BinTree_RotateLeft(BINTREEBASENODE *pANode, BINTREEBASENODE **ppRoot );
void BinTree_RotateRight(BINTREEBASENODE *pANode, BINTREEBASENODE **ppRoot );

void BinTree_CheckParent(BINTREEBASENODE *pRootNode);

INT BinTree_Insert(BINTREEBASENODE **pRoot, void *pData, COMPAREFUNC CompareFunc, INT nMagic);

void BinTree_InOrderTraverse(BINTREE *pTree, VISITFUNC VisitFunc);
void BinTree_PreOrderTraverse(BINTREE *pTree, VISITFUNC VisitFunc);
void BinTree_PostOrderTraverse(BINTREE *pTree, VISITFUNC VisitFunc);

#ifdef __cplusplus
}
#endif

#endif /* __BINTREE_H__ */

⌨️ 快捷键说明

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