KBinTree.h
上传用户:dzyhzl
上传日期:2019-04-29
资源大小:56270k
文件大小:2k
源码类别:

模拟服务器

开发平台:

C/C++

  1. #ifndef KBINTREE_H
  2. #define KBINTREE_H
  3. #include "KEngine.h"
  4. class ENGINE_API TBinTreeNode
  5. {
  6. TBinTreeNode(){ pParent = pLeftChild = pRightChild =  NULL; }
  7. public:
  8. virtual BOOL operator>(TBinTreeNode& p) = 0;
  9. virtual BOOL operator==(TBinTreeNode& p) = 0;
  10.   virtual BOOL operator<(TBinTreeNode& p) = 0;
  11. TBinTreeNode * pParent; //父
  12. TBinTreeNode * pLeftChild; //左子
  13. TBinTreeNode * pRightChild; //右子
  14. }; //按照文件名或其它属性作为脚本标识的排序二叉树
  15. class ENGINE_API KBinTree
  16. {
  17. public:
  18. KBinTree();
  19. //查找关键字与pKeyNode一致的结点,成功*pResult为True并返回结点指针.
  20. TBinTreeNode * Search(TBinTreeNode* pKeyNode, BOOL * pResult);
  21. //插入结点,成功返回新插的结点指针,否则为空
  22. TBinTreeNode * Insert(TBinTreeNode *pNewNode);
  23. //删除本结点
  24. BOOL    RemoveThisNode(TBinTreeNode * pNode);
  25. //删除二叉树中与pKeyNode一致的结点
  26. BOOL    RemoveKeyNode(TBinTreeNode * pNode);
  27. DWORD    GetCount()
  28. { int OldCount = m_TempCount;
  29. return InOrder(m_pTreeRoot) - OldCount;
  30. };
  31. TBinTreeNode * GetRoot(){return m_pTreeRoot; };
  32. private:
  33. TBinTreeNode * m_pTreeRoot; //二叉树根支点
  34. int m_TempCount;
  35. TBinTreeNode * AddNode(TBinTreeNode *pNewNode, TBinTreeNode *pTBinTreeNode);
  36. TBinTreeNode * RemoveNode(TBinTreeNode * pTBinTreeNode, TBinTreeNode ** ppRootTBinTreeNode);
  37. TBinTreeNode * Search(TBinTreeNode * pParentTBinTreeNode, TBinTreeNode * pTBinTreeNode, TBinTreeNode * pKeyNode, BOOL * pResult);
  38. TBinTreeNode * FindLess(TBinTreeNode * pTBinTreeNode);
  39. DWORD    InOrder(TBinTreeNode * pTBinTreeNode);//中序遍历
  40. };
  41. #endif //KBINTREE_H