麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C > 正文

二叉查找樹的插入,刪除,查找

2020-01-26 15:54:43
字體:
供稿:網(wǎng)友

二叉查找樹是滿足以下條件的二叉樹:
1、左子樹上的所有節(jié)點(diǎn)值均小于根節(jié)點(diǎn)值,
2、右子樹上的所有節(jié)點(diǎn)值均不小于根節(jié)點(diǎn)值,
3、左右子樹也滿足上述兩個(gè)條件。

二叉查找樹的插入過程如下:
1.若當(dāng)前的二叉查找樹為空,則插入的元素為根節(jié)點(diǎn),
2.若插入的元素值小于根節(jié)點(diǎn)值,則將元素插入到左子樹中,
3.若插入的元素值不小于根節(jié)點(diǎn)值,則將元素插入到右子樹中。

二叉查找樹的刪除,分三種情況進(jìn)行處理:
1.p為葉子節(jié)點(diǎn),直接刪除該節(jié)點(diǎn),再修改其父節(jié)點(diǎn)的指針(注意分是根節(jié)點(diǎn)和不是根節(jié)點(diǎn)),如圖a。

2.p為單支節(jié)點(diǎn)(即只有左子樹或右子樹)。讓p的子樹與p的父親節(jié)點(diǎn)相連,刪除p即可;(注意分是根節(jié)點(diǎn)和不是根節(jié)點(diǎn));如圖b。

3.p的左子樹和右子樹均不空。找到p的后繼y,因?yàn)閥一定沒有左子樹,所以可以刪除y,并讓y的父親節(jié)點(diǎn)成為y的右子樹的父親節(jié)點(diǎn),并用y的值代替p的值;或者方法二是找到p的前驅(qū)x,x一定沒有右子樹,所以可以刪除x,并讓x的父親節(jié)點(diǎn)成為y的左子樹的父親節(jié)點(diǎn)。如圖c。

  

插入節(jié)點(diǎn)的代碼:

復(fù)制代碼 代碼如下:

struct node
{
    int val;
    pnode lchild;
    pnode rchild;
};

pnode BT = NULL;


//遞歸方法插入節(jié)點(diǎn)
pnode insert(pnode root, int x)
{
    pnode p = (pnode)malloc(LEN);
    p->val = x;
    p->lchild = NULL;
    p->rchild = NULL;
    if(root == NULL){
        root = p;   
    }   
    else if(x < root->val){
        root->lchild = insert(root->lchild, x);   
    }
    else{
        root->rchild = insert(root->rchild, x);   
    }
    return root;
}

//非遞歸方法插入節(jié)點(diǎn)
void insert_BST(pnode q, int x)
{
    pnode p = (pnode)malloc(LEN);
    p->val = x;
    p->lchild = NULL;
    p->rchild = NULL;
    if(q == NULL){
        BT = p;
        return ;   
    }       
    while(q->lchild != p && q->rchild != p){
        if(x < q->val){
            if(q->lchild){
                q = q->lchild;   
            }   
            else{
                q->lchild = p;
            }       
        }   
        else{
            if(q->rchild){
                q = q->rchild;   
            }   
            else{
                q->rchild = p;   
            }
        }
    }
    return;
}


查找節(jié)點(diǎn)的代碼:
復(fù)制代碼 代碼如下:

pnode search_BST(pnode p, int x)
{
    bool solve = false;
    while(p && !solve){
        if(x == p->val){
            solve = true;   
        }   
        else if(x < p->val){
            p = p->lchild;   
        }
        else{
            p = p->rchild;   
        }
    }
    if(p == NULL){
        cout << "沒有找到" << x << endl;   
    }
    return p;
}

刪除節(jié)點(diǎn)的代碼
復(fù)制代碼 代碼如下:

bool delete_BST(pnode p, int x) //返回一個(gè)標(biāo)志,表示是否找到被刪元素
{
    bool find = false;
    pnode q;
    p = BT;
    while(p && !find){  //尋找被刪元素
        if(x == p->val){  //找到被刪元素
            find = true;   
        }   
        else if(x < p->val){ //沿左子樹找
            q = p;
            p = p->lchild;   
        }
        else{   //沿右子樹找
            q = p;
            p = p->rchild;   
        }
    }
    if(p == NULL){   //沒找到
        cout << "沒有找到" << x << endl;   
    }

    if(p->lchild == NULL && p->rchild == NULL){  //p為葉子節(jié)點(diǎn)
        if(p == BT){  //p為根節(jié)點(diǎn)
            BT = NULL;   
        }
        else if(q->lchild == p){  
            q->lchild = NULL;
        }       
        else{
            q->rchild = NULL;   
        }
        free(p);  //釋放節(jié)點(diǎn)p
    }
    else if(p->lchild == NULL || p->rchild == NULL){ //p為單支子樹
        if(p == BT){  //p為根節(jié)點(diǎn)
            if(p->lchild == NULL){
                BT = p->rchild;   
            }   
            else{
                BT = p->lchild;   
            }
        }   
        else{
            if(q->lchild == p && p->lchild){ //p是q的左子樹且p有左子樹
                q->lchild = p->lchild;    //將p的左子樹鏈接到q的左指針上
            }   
            else if(q->lchild == p && p->rchild){
                q->lchild = p->rchild;   
            }
            else if(q->rchild == p && p->lchild){
                q->rchild = p->lchild;   
            }
            else{
                q->rchild = p->rchild;
            }
        }
        free(p);
    }
    else{ //p的左右子樹均不為空
        pnode t = p;
        pnode s = p->lchild;  //從p的左子節(jié)點(diǎn)開始
        while(s->rchild){  //找到p的前驅(qū),即p左子樹中值最大的節(jié)點(diǎn)
            t = s;  
            s = s->rchild;   
        }
        p->val = s->val;   //把節(jié)點(diǎn)s的值賦給p
        if(t == p){
            p->lchild = s->lchild;   
        }   
        else{
            t->rchild = s->lchild;   
        }
        free(s);
    }
    return find;
}

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 亚洲一区二区在线免费 | 日韩黄色片在线观看 | 在线成人一区 | 成年人视频免费看 | 成人视屏在线 | 欧美性生活区 | 欧美人的天堂一区二区三区 | 色毛片| 在线中文资源免费 | gogo全球大胆高清人露出91 | 欧美成人免费小视频 | av在线免费看网址 | 久久久久亚洲精品国产 | 久久最新视频 | 哪里可以看免费的av | 99re66热这里只有精品8 | 国产精品99久久久久久久女警 | 成人毛片100免费观看 | 国产精品免费一区二区三区四区 | 国产精品久久久久久久久久大牛 | 中国的免费的视频 | 91丨九色丨国产在线观看 | 蜜桃视频在线观看免费 | 久久sp | 国产精品色综合 | 国产精品伊人久久 | 国产成人精品免费视频大全最热 | 一级裸体视频 | 久久亚洲一区二区三区成人国产 | 越南一级黄色片 | 午夜天堂在线视频 | av观看国产 | 99视频观看 | 亚洲一级片在线观看 | 欧美77| 免费a级毛片大学生免费观看 | 免费黄色入口 | 羞羞的视频免费在线观看 | 国产乱free国语对白 | 黄色视屏免费看 | 免费一级特黄欧美大片勹久久网 |