二叉查找树实现类——二叉链表

1155人阅读 评论(0)

1. 若它的左子树不空，则左子树上所有结点的值均小于它的根结点的值；
2. 若它的右子树不空，则右子树上所有结点的值均大于它的根结点的值；
3. 它的左、右子树也分别为二叉排序树。

#include <iostream>

using namespace std;

template <class NodeType>
class BSTreeNode
{
public:
NodeType value;
BSTreeNode* lChild, rChild;

BSTreeNode();
};

template <class NodeType>
BSTreeNode<NodeType>::BSTreeNode()
{
lChild = NULL;
rChild = NULL;
}

template <class NodeType>
class BinarySearchTree
{
public:
BinarySearchTree();
BinarySearchTree(BSTreeNode<NodeType> *node);
~BinarySearchTree();

void CreatBinaryTree(BSTreeNode<NodeType> *node);
void DestroyTree(BSTreeNode<NodeType> *node);
void InsertValue(NodeType value);							//NodeType必须重载了==及>操作符
void DeleteNode(BSTreeNode<NodeType> *node);				//NodeType必须重载了=操作符
BSTreeNode<NodeType>* FindValue(NodeType value);			//NodeType必须重载了=,==及>操作符

private:
BSTreeNode<NodeType> *root;
void CopyTree(BSTreeNode<NodeType> *position, BSTreeNode<NodeType> *node);
void InsertValue(BSTreeNode<NodeType> *node, NodeType value);
BSTreeNode<NodeType>* FindValueFrom(BSTreeNode<NodeType> *node, NodeType value);
};

template <class NodeType>
BinarySearchTree<NodeType>::BinarySearchTree()
{
root = NULL;
}

template <class NodeType>
BinarySearchTree<NodeType>::BinarySearchTree(BSTreeNode<NodeType> *node)
{
CreatBinaryTree(node);
}

template <class NodeType>
BinarySearchTree<NodeType>::~BinarySearchTree()
{
DestroyTree(root);
}

template <class NodeType>
void BinarySearchTree<NodeType>::CreatBinaryTree(BSTreeNode<NodeType> *node)
{
CopyTree(root, node);
}

template <class NodeType>
void BinarySearchTree<NodeType>::CopyTree(BSTreeNode<NodeType> *position, BSTreeNode<NodeType> *node)
{
if (NULL == node)
{
position = NULL;
return ;
}

position = new BSTreeNode<NodeType>;
position->value = node->value;

CopyTree(position->lChild, node->lChild);
CopyTree(position->rChild, node->rChild);
}

template <class NodeType>
void BinarySearchTree<NodeType>::DestroyTree(BSTreeNode<NodeType> *node)
{
if (NULL == node)
{
return ;
}

DestroyTree(node->lChild);
DestroyTree(node->rChild);

delete node;
}

template <class NodeType>
void BinarySearchTree<NodeType>::InsertValue(NodeType value)
{
InsertValue(root, value);
}

template <class NodeType>
void BinarySearchTree<NodeType>::InsertValue(BSTreeNode<NodeType> *node, NodeType value)
{
if (NULL == node)
{
node = new BSTreeNode<NodeType>;
node->value = value;
return ;
}

if (node->value == value)
{
return ;
}
else if ( node->value > value)
{
InsertValue(node->lChild, value);
}
else
{
InsertValue(node->rChild, value);
}
}

template <class NodeType>
BSTreeNode<NodeType>* BinarySearchTree<NodeType>::FindValueFrom(BSTreeNode<NodeType> *node, NodeType value)
{
if (NULL == node)
{
return NULL;
}

if (node->value == value)
{
return node;
}
else if (node->value > value)
{
return FindValueFrom(node->lChild, value);
}
else
{
return FindValueFrom(node->rChild, value);
}
}

template <class NodeType>
BSTreeNode<NodeType>* BinarySearchTree<NodeType>::FindValue(NodeType value)
{
return FindValueFrom(root,value);
}

template <class NodeType>
void BinarySearchTree<NodeType>::DeleteNode(BSTreeNode<NodeType> *node)
{
if (NULL == node)
{
return ;
}

BSTreeNode<NodeType> *currentNode = FindValue(node->value);
if (NULL == currentNode)
{
return ;
}

BSTreeNode<NodeType> *lastNode;
while (currentNode != NULL)
{
lastNode = currentNode;
currentNode->value = currentNode->rChild.value;
currentNode = currentNode->rChild;
}

delete currentNode;
lastNode->rChild = NULL;
}


0
0

【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐（算法+实战）--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮

* 以上用户言论只代表其个人观点，不代表CSDN网站的观点或立场
个人资料
• 访问：515333次
• 积分：5676
• 等级：
• 排名：第4560名
• 原创：125篇
• 转载：29篇
• 译文：0篇
• 评论：26条
文章分类
最新评论