亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

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

2020-01-26 15:54:43
字體:
來源:轉載
供稿:網友

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

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

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

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

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

  

插入節點的代碼:

復制代碼 代碼如下:

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

pnode BT = NULL;


//遞歸方法插入節點
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;
}

//非遞歸方法插入節點
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;
}


查找節點的代碼:
復制代碼 代碼如下:

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;
}

刪除節點的代碼
復制代碼 代碼如下:

bool delete_BST(pnode p, int x) //返回一個標志,表示是否找到被刪元素
{
    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為葉子節點
        if(p == BT){  //p為根節點
            BT = NULL;   
        }
        else if(q->lchild == p){  
            q->lchild = NULL;
        }       
        else{
            q->rchild = NULL;   
        }
        free(p);  //釋放節點p
    }
    else if(p->lchild == NULL || p->rchild == NULL){ //p為單支子樹
        if(p == BT){  //p為根節點
            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的左子節點開始
        while(s->rchild){  //找到p的前驅,即p左子樹中值最大的節點
            t = s;  
            s = s->rchild;   
        }
        p->val = s->val;   //把節點s的值賦給p
        if(t == p){
            p->lchild = s->lchild;   
        }   
        else{
            t->rchild = s->lchild;   
        }
        free(s);
    }
    return find;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
高清欧美性猛交xxxx黑人猛交| 国产精品成人免费电影| 欧美激情videos| 国产suv精品一区二区三区88区| 国产精品久久久av久久久| 国产成人综合精品| 国产成人精品免费久久久久| 91精品视频在线播放| 夜色77av精品影院| 久久免费国产精品1| 中文字幕av一区中文字幕天堂| 亚洲成人在线视频播放| 性色av一区二区三区免费| 亚洲欧美国产高清va在线播| 欧美黄色www| 亚洲a在线观看| 欧美成人在线网站| 亚洲bt天天射| 大量国产精品视频| 精品色蜜蜜精品视频在线观看| 宅男66日本亚洲欧美视频| 国产精品一区二区三| 欧美成人精品在线| 高清一区二区三区四区五区| 久青草国产97香蕉在线视频| 中文字幕国产精品久久| 亚洲成人a**站| 国产精品一区二区久久久久| 亚洲天堂开心观看| 亚洲人成电影在线| 97超级碰碰碰久久久| 国产精品黄色av| 欧美中文在线观看国产| 亚洲18私人小影院| 国产97色在线| 欧美激情一级二级| 国语自产偷拍精品视频偷| 性色av一区二区三区红粉影视| 精品国内自产拍在线观看| 国产精品久久久久国产a级| 久久久久久这里只有精品| 日韩免费在线观看视频| 国产精品福利久久久| 欧美老妇交乱视频| 日韩欧美在线观看| 欧美刺激性大交免费视频| 欧美国产精品日韩| 久久精品91久久香蕉加勒比| 国产精品一区久久| 97色在线播放视频| 欧美激情网站在线观看| 羞羞色国产精品| 成人av电影天堂| 欧美激情视频三区| 成人国产精品日本在线| 国产精品精品国产| 国产一区二区成人| 亚洲片国产一区一级在线观看| 91色琪琪电影亚洲精品久久| 国产精品高潮在线| 成人伊人精品色xxxx视频| 尤物九九久久国产精品的分类| 日韩免费电影在线观看| 日韩av手机在线观看| 亚洲电影免费观看高清完整版| 国产精品狠色婷| 亚洲精品一区中文| 国产在线观看精品| 91色视频在线观看| 91精品国产91久久久久福利| 热re99久久精品国产66热| 国产一区二区三区在线免费观看| 精品久久久久久久大神国产| 色噜噜久久综合伊人一本| 成人做爰www免费看视频网站| 亚洲第一色中文字幕| 久久成人免费视频| 国产欧美va欧美va香蕉在线| 国产精品免费久久久| 日本精品久久久久久久| 成人免费视频a| 日韩a**站在线观看| 亚洲欧美国产日韩中文字幕| 欧美性猛交xxxx偷拍洗澡| 久久久久久久久国产精品| 国产成人在线一区| 精品国产户外野外| 久久成人在线视频| 欧美午夜性色大片在线观看| 影音先锋欧美精品| 国产精品中文字幕在线| 亚洲天堂网站在线观看视频| 日本精品va在线观看| 午夜精品久久久久久99热软件| 在线日韩欧美视频| 91欧美精品午夜性色福利在线| 亚洲天堂视频在线观看| 久久久www成人免费精品张筱雨| 亚洲专区国产精品| 亚洲国产精品推荐| 最近2019年好看中文字幕视频| 日韩成人在线播放| 欧美激情一区二区久久久| 国产精品三级美女白浆呻吟| 热久久99这里有精品| 欧美日韩精品中文字幕| 欧美日韩国产一区二区三区| xxx欧美精品| 久久精品国产清自在天天线| 91在线观看欧美日韩| 久久久人成影片一区二区三区观看| 最近2019年中文视频免费在线观看| 亚洲第一色中文字幕| 午夜精品久久17c| 久久精品精品电影网| 国产午夜精品视频| 久久精品国产电影| 亚洲欧美视频在线| 国产一区二区三区在线看| 久久久免费观看| 欧美最顶级丰满的aⅴ艳星| 欧美另类69精品久久久久9999| 亚洲精品成人网| 日韩在线资源网| 亚洲综合在线播放| 精品magnet| 国产日韩欧美自拍| 国产精品极品美女粉嫩高清在线| 日韩美女av在线免费观看| 欧美影院成年免费版| 亚洲欧美三级伦理| 国产精品视频男人的天堂| 亚洲精品美女免费| 九九九热精品免费视频观看网站| 国产精品高清免费在线观看| 91免费的视频在线播放| 亚洲激情小视频| 亚洲xxxx在线| 在线观看视频亚洲| 久热精品视频在线免费观看| 亚洲激情电影中文字幕| 欧美一级黄色网| 91av视频在线观看| 亚洲网址你懂得| 亚洲综合在线小说| 揄拍成人国产精品视频| 欧美国产日产韩国视频| 日韩a**中文字幕| 久久久久久伊人| 亚洲欧美日韩成人| 久久综合网hezyo| 国产成人精品一区二区| 国产精品人成电影在线观看| 日韩精品免费在线播放| 久久久亚洲影院| 欧美成人精品一区二区| 久久亚洲综合国产精品99麻豆精品福利| 亚洲黄色av网站| www.亚洲人.com| 久久久久久尹人网香蕉| 亚洲区bt下载| 国产精品久久久久福利| 国产日韩欧美在线播放| 亚洲精品国产品国语在线|