欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

二叉查找樹(shù)的插入,刪除,查找

 更新時(shí)間:2013年09月04日 09:39:20   作者:  
以下是對(duì)二叉查找樹(shù)的插入與刪除以及查找進(jìn)行了詳細(xì)的介紹,需要的朋友可以 過(guò)來(lái)參考下

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

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

二叉查找樹(shù)的刪除,分三種情況進(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)(即只有左子樹(shù)或右子樹(shù))。讓p的子樹(shù)與p的父親節(jié)點(diǎn)相連,刪除p即可;(注意分是根節(jié)點(diǎn)和不是根節(jié)點(diǎn));如圖b。

3.p的左子樹(shù)和右子樹(shù)均不空。找到p的后繼y,因?yàn)閥一定沒(méi)有左子樹(shù),所以可以刪除y,并讓y的父親節(jié)點(diǎn)成為y的右子樹(shù)的父親節(jié)點(diǎn),并用y的值代替p的值;或者方法二是找到p的前驅(qū)x,x一定沒(méi)有右子樹(shù),所以可以刪除x,并讓x的父親節(jié)點(diǎn)成為y的左子樹(shù)的父親節(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 << "沒(méi)有找到" << 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){ //沿左子樹(shù)找
            q = p;
            p = p->lchild;   
        }
        else{   //沿右子樹(shù)找
            q = p;
            p = p->rchild;   
        }
    }
    if(p == NULL){   //沒(méi)找到
        cout << "沒(méi)有找到" << 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為單支子樹(shù)
        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的左子樹(shù)且p有左子樹(shù)
                q->lchild = p->lchild;    //將p的左子樹(shù)鏈接到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的左右子樹(shù)均不為空
        pnode t = p;
        pnode s = p->lchild;  //從p的左子節(jié)點(diǎn)開(kāi)始
        while(s->rchild){  //找到p的前驅(qū),即p左子樹(shù)中值最大的節(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;
}

相關(guān)文章

  • 詳解C語(yǔ)言#define預(yù)處理宏定義

    詳解C語(yǔ)言#define預(yù)處理宏定義

    本文主要介紹了C語(yǔ)言#define預(yù)處理宏定義,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C++?Protobuf的學(xué)習(xí)使用指南

    C++?Protobuf的學(xué)習(xí)使用指南

    protocol?buffers是一種語(yǔ)言無(wú)關(guān)、平臺(tái)無(wú)關(guān)、可擴(kuò)展的序列化結(jié)構(gòu)數(shù)據(jù)的方法,它可用于(數(shù)據(jù))通信協(xié)議、數(shù)據(jù)存儲(chǔ)等,下面就來(lái)跟隨小編一起簡(jiǎn)單學(xué)習(xí)一下它的使用吧
    2023-07-07
  • Qt自定義Widget實(shí)現(xiàn)互斥效果詳解

    Qt自定義Widget實(shí)現(xiàn)互斥效果詳解

    在使用Qt時(shí),可能會(huì)遇到這種問(wèn)題:多個(gè)控件互斥,類(lèi)似于QRadiButton控件,但又不是單純的QRadioButton控件,互斥的可能是一個(gè)窗口,也可能是幾個(gè)按鈕,等等多種情況。本文將介紹利用Qt自定義Widget實(shí)現(xiàn)的互斥效果,需要的可以參考一下
    2022-01-01
  • 在vs2010中,輸出當(dāng)前文件路徑與源文件當(dāng)前行號(hào)的解決方法

    在vs2010中,輸出當(dāng)前文件路徑與源文件當(dāng)前行號(hào)的解決方法

    本篇文章是對(duì)在vs2010中,輸出當(dāng)前文件路徑與源文件當(dāng)前行號(hào)的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語(yǔ)言實(shí)現(xiàn)帶頭雙向循環(huán)鏈表的接口

    C語(yǔ)言實(shí)現(xiàn)帶頭雙向循環(huán)鏈表的接口

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)帶頭雙向循環(huán)鏈表的接口,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 一文詳解C++中的類(lèi)型轉(zhuǎn)化

    一文詳解C++中的類(lèi)型轉(zhuǎn)化

    說(shuō)起類(lèi)型轉(zhuǎn)化,我們?cè)贑語(yǔ)言之前的學(xué)習(xí)中可以了解到,類(lèi)型轉(zhuǎn)換可以分為兩種情況:隱式類(lèi)型轉(zhuǎn)化;顯示類(lèi)型轉(zhuǎn)化。但是為什么在c++中還要繼續(xù)對(duì)類(lèi)型轉(zhuǎn)化做文章呢?我們一起來(lái)看
    2023-04-04
  • c語(yǔ)言操作文本的基本使用方法

    c語(yǔ)言操作文本的基本使用方法

    這篇文章主要介紹了c語(yǔ)言操作文本的基本使用方法,需要的朋友可以參考下
    2014-04-04
  • C++回調(diào)函數(shù)的理解和使用教程

    C++回調(diào)函數(shù)的理解和使用教程

    這篇文章主要給大家介紹了關(guān)于C++回調(diào)函數(shù)的理解和使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • C語(yǔ)言 TerminateProcess函數(shù)案例詳解

    C語(yǔ)言 TerminateProcess函數(shù)案例詳解

    這篇文章主要介紹了C語(yǔ)言 TerminateProcess函數(shù)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++中的string庫(kù)函數(shù)常見(jiàn)函數(shù)的作用和使用方法

    C++中的string庫(kù)函數(shù)常見(jiàn)函數(shù)的作用和使用方法

    這篇文章主要介紹了C++中的string庫(kù)函數(shù)常見(jiàn)函數(shù)的作用和使用方法,庫(kù)函數(shù)的靈活應(yīng)用是程序員的一大重要技能,本文通過(guò)實(shí)例實(shí)例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-04-04

最新評(píng)論