Code/Resource
Windows Develop
Linux-Unix program
Internet-Socket-Network
Web Server
Browser Client
Ftp Server
Ftp Client
Browser Plugins
Proxy Server
Email Server
Email Client
WEB Mail
Firewall-Security
Telnet Server
Telnet Client
ICQ-IM-Chat
Search Engine
Sniffer Package capture
Remote Control
xml-soap-webservice
P2P
WEB(ASP,PHP,...)
TCP/IP Stack
SNMP
Grid Computing
SilverLight
DNS
Cluster Service
Network Security
Communication-Mobile
Game Program
Editor
Multimedia program
Graph program
Compiler program
Compress-Decompress algrithms
Crypt_Decrypt algrithms
Mathimatics-Numerical algorithms
MultiLanguage
Disk/Storage
Java Develop
assembly language
Applications
Other systems
Database system
Embeded-SCM Develop
FlashMX/Flex
source in ebook
Delphi VCL
OS Develop
MiddleWare
MPI
MacOS develop
LabView
ELanguage
Software/Tools
E-Books
Artical/Document
KBinTree.h
Package: SwordOnline.rar [view]
Upload User: dzyhzl
Upload Date: 2019-04-29
Package Size: 56270k
Code Size: 2k
Category:
Game Server Simulator
Development Platform:
C/C++
- #ifndef KBINTREE_H
- #define KBINTREE_H
- #include "KEngine.h"
- class ENGINE_API TBinTreeNode
- {
- TBinTreeNode(){ pParent = pLeftChild = pRightChild = NULL; }
- public:
- virtual BOOL operator>(TBinTreeNode& p) = 0;
- virtual BOOL operator==(TBinTreeNode& p) = 0;
- virtual BOOL operator<(TBinTreeNode& p) = 0;
- TBinTreeNode * pParent; //父
- TBinTreeNode * pLeftChild; //左子
- TBinTreeNode * pRightChild; //右子
- }; //按照文件名或其它属性作为脚本标识的排序二叉树
- class ENGINE_API KBinTree
- {
- public:
- KBinTree();
- //查找关键字与pKeyNode一致的结点,成功*pResult为True并返回结点指针.
- TBinTreeNode * Search(TBinTreeNode* pKeyNode, BOOL * pResult);
- //插入结点,成功返回新插的结点指针,否则为空
- TBinTreeNode * Insert(TBinTreeNode *pNewNode);
- //删除本结点
- BOOL RemoveThisNode(TBinTreeNode * pNode);
- //删除二叉树中与pKeyNode一致的结点
- BOOL RemoveKeyNode(TBinTreeNode * pNode);
- DWORD GetCount()
- { int OldCount = m_TempCount;
- return InOrder(m_pTreeRoot) - OldCount;
- };
- TBinTreeNode * GetRoot(){return m_pTreeRoot; };
- private:
- TBinTreeNode * m_pTreeRoot; //二叉树根支点
- int m_TempCount;
- TBinTreeNode * AddNode(TBinTreeNode *pNewNode, TBinTreeNode *pTBinTreeNode);
- TBinTreeNode * RemoveNode(TBinTreeNode * pTBinTreeNode, TBinTreeNode ** ppRootTBinTreeNode);
- TBinTreeNode * Search(TBinTreeNode * pParentTBinTreeNode, TBinTreeNode * pTBinTreeNode, TBinTreeNode * pKeyNode, BOOL * pResult);
- TBinTreeNode * FindLess(TBinTreeNode * pTBinTreeNode);
- DWORD InOrder(TBinTreeNode * pTBinTreeNode);//中序遍历
- };
- #endif //KBINTREE_H