缩写:BST(binary search tree)
定义:一颗二叉树或者是空二叉树,此二叉树具有如下性质
左子树上所有结点的关键字均小于根结点的关键字。
右子树上所有结点的关键字均大于根结点的关键字。
左子树和右子树又各是一颗二叉搜索树。
------->> 左子树结点值<根结点值<右子树结点值
对一颗二叉搜索树进行中序遍历,可以得到一个递增的有序序列
二叉搜索树的查找
1.若树非空,目标值与根结点的值比较.
2.若相等则查找成功,若小于根结点,则在左子树上查找,否则在右子树上查找。
3.查找成功,返回结点指针;查找失败返回NULL;
//二叉排序树中查找值为key的结点
BSTNode *BST_search(BSTree T,int key)
{
while(T!=NULL&&key!=T->key) //若树空或者等于根结点的值,则循环结束
{
if(key<T->key) T=T->lchild; //小于,则在左子树上查找
else T=T->rchild; //大于,则在右子树上查找
}
return T;
}
二叉搜索树的插入
若原二叉搜索树为空,则直接插入结点。若关键字k小于根结点值,则插到左子树。若关键字k大于根结点值,则插入到右子树。
//在二叉搜索树插入关键字为k的新结点(递归实现)
int BST_Insert(BSTree &T,int k)
{
if(T==NULL) //如果原树为空,新插入的结点为根结点
{
T=(BSTree)malloc(sizeof(BSTNode));
T->key=k;
T->lchild=T->rchild=NULL;
return 1; //返回1则说明插入成功
}
else if(k==T->key) //树中存在相同关键字的结点,插入失败
return 0;
else if(k<T->key) //插入到T的左子树
return BST_Insert(T->lchild,k);
else //插入到T的右子树
return BST_Insert(T->rchild,k);
}
二叉搜索树的删除
1.若被删除结点z是叶子结点,则直接删除,不会破坏二叉排序树的性质
2.若结点z只有一颗左子树或右子树,则让z的子树成为z父结点的子树,替代z的位置。
3.若结点z有左右两颗子树,则令z的直接后继(或直接前驱)替代z,然后从二叉排序树中删去这个直接后继(或直接前驱),这样就转换成了第一或第二种情况。
查找效率分析
查找成功的平均查找长度ASL(average search length)