📄 bintree.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 + -