二叉搜索树的操作集

增删查改

!!!重点关注删除

BinTree Insert( BinTree BST, ElementType X )
{
    if(!BST){
        BST=(BinTree)malloc(sizeof(struct TNode));
        BST->Data=X;
        BST->Left=NULL;
        BST->Right=NULL;
        return BST;
    }
    else{
        if(X>BST->Data)
        {
            BST->Right=Insert(BST->Right,X);
        }
        else{
            BST->Left=Insert(BST->Left,X);
        }
    }
    return BST;
}


BinTree Delete( BinTree BST, ElementType X )
{
     BinTree tmp;
    if(!BST)printf("Not Found\n");
    else if(X>BST->Data)  BST->Right=Delete(BST->Right,X);
    else if(X<BST->Data)  BST->Left=Delete(BST->Left,X);
    else{
        if(BST->Left&&BST->Right){
            tmp=FindMin(BST->Right);
            BST->Data=tmp->Data;
            BST->Right=Delete(BST->Right,tmp->Data);
        }
        else //包含只存在一个子树和没有子树的情况
        {
            tmp=BST;
            if(BST->Right==NULL)  BST=BST->Left; 
            else if(BST->Left==NULL)  BST=BST->Right;
/*
if(BST->Right) BST=BST->Right;  
else if(BST->Left) BST=BST->Left;
else BST=NULL;  这样判断的时候记得考虑左右子树都不存在时,BST应该赋值为NULL
*/
            free(tmp);
        }
    }
    return BST;
}
Position Find( BinTree BST, ElementType X )
{
    if(!BST)return NULL;
    else if(X>BST->Data)
    {
        return Find(BST->Right,X);
    }
    else if(X<BST->Data)
    {
        return Find(BST->Left,X);
    }
   else return BST;
}
Position FindMin( BinTree BST )
{
    if(!BST)return NULL;
    while(BST->Left!=NULL)
        BST=BST->Left;
    return BST;
   
}
Position FindMax( BinTree BST )
{
    if(!BST)return NULL;
    while(BST->Right!=NULL)
        BST=BST->Right;
    return BST;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值