青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Just enjoy programming

二叉查找樹實(shí)現(xiàn)

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

/*結(jié)構(gòu)體節(jié)點(diǎn)*/
typedef struct  _node{
    int key;
    struct _node *left;
    struct _node *right;
    struct _node *parent;
}node;


/*插入節(jié)點(diǎn)*/
void insert(node *root,node *toInsert)
{
    node *p,*q;
    p=root;
    q=NULL;
    if(toInsert==NULL || root==NULL)
    {
        return;
    }

    while(p!=NULL)
    {
        q=p;/*記錄父節(jié)點(diǎn)*/
        if(toInsert->key<p->key)
        {
            p=p->left;
        }else{
            p=p->right;
        }    
    }
    if(toInsert->key<q->key)
    {
        q->left=toInsert;
    }else{
        q->right=toInsert;
    }
    toInsert->parent=q;
    toInsert->left=NULL;
    toInsert->right=NULL;
}

/*遞歸中序遍歷根節(jié)點(diǎn)*/
void middleSearch(node *root)
{
    if(root!=NULL)
    {
        middleSearch(root->left);
        printf("%d\t",root->key);
        middleSearch(root->right);
    }
}
/*先序遍歷*/
void preSearch(node *root)
{
    if(root!=NULL)
    {
        printf("%d\t",root->key);
        preSearch(root->left);
        preSearch(root->right);
    }
}

/*查找返回節(jié)點(diǎn)關(guān)鍵字為key的節(jié)點(diǎn)*/
node* search(node *root,int key)
{
    node *p=root;
    while(p!=NULL)
    {
        if(key<p->key)
        {
            p=p->left;
        }else if(key>p->key)
        {
            p=p->right;
        }else
            break;
    }
    return p;
}

/*查找二叉樹最小值*/
node *minimun(node *root)
{
    node *p=root;
    if(p==NULL)
        return p;
    while(p->left!=NULL)
        p=p->left;
    printf("min %d\n",p->key);
    return p;
}

/*查找二叉樹最大值*/
node *maximun(node *root)
{
    node *p=root;
    if(p==NULL)
        return;
    while(p->right!=NULL)
        p=p->right;
    printf("max %d\n",p->key);
    return p;
}
/*找節(jié)點(diǎn)后續(xù)*/
node* successor(node *x)
{
    node *p;
    if(NULL==x)
        return x;
    if(x->right!=NULL)
        return minimun(x->right);
    p=x->parent;
    while(p!=NULL && p->right==x)
    {
        x=p;
        p=p->parent;
    }
    return p;
}

/*刪除節(jié)點(diǎn)*/
void delete(node *root,node *toDelete)
{
    node *p,*q;
    int key;
    if(root==NULL || toDelete==NULL)
        return ;
    p=toDelete->parent;

    /*第一種情況,要?jiǎng)h除的節(jié)點(diǎn)的左右子樹都為空*/
    if(toDelete->left ==NULL && toDelete->right ==NULL)
    {
        if(p==NULL)/*要?jiǎng)h除的是根節(jié)點(diǎn)*/
        {
            free(toDelete);
            return;
        }
        if(p->left==toDelete)
        {
            p->left=NULL;
        }else
            p->right=NULL;
        free(toDelete);

    }

    /*第二種情況,要?jiǎng)h除的左子樹為空,右子樹不為空*/
    else if(toDelete->left==NULL)
    {    
        if(p==NULL)
        {
            q=root->right;
            root->key=q->key;
            root->left=q->left;
            root->right=q->right;

            free(q);
            return;
        }
        else if(p->left==toDelete)
        {
            p->left=toDelete->right;
        }else
            p->right=toDelete->right;
        toDelete->right->parent=p;
        free(toDelete);
    }

    /* 第三種情況,要?jiǎng)h除的右子樹為空,左子樹不為空*/
    else if(toDelete->right==NULL)
    {
        if(p==NULL)
        {
            q=root->left;
            root->key=q->key;
            root->left=q->left;
            root->right=q->right;
            root->parent=NULL;
            free(q);
            return;
        }
        else if(p->left==toDelete)
        {
            p->left=toDelete->left;
        }else
            p->right=toDelete->right;
        toDelete->parent=p;
        free(toDelete);
    }

    /* 第四種情況,要?jiǎng)h除的左右子樹都不為空*/
    else{
            q=successor(toDelete);
            key=q->key;
            delete(root,q);
            toDelete->key=key;
    }
}

int main()
{
    node *root;

    int a[12]={15,5,3,12,10,13,6,7,16,20,18,23};
    node *toInsert;
    node *x,*y;
    int i;
    /*創(chuàng)建頭節(jié)點(diǎn)*/
    if((root=(node*)malloc(sizeof(node)))==NULL)
    {
        perror("malloc error");
        exit(1);
    }
    root->key=a[0];
    /*插入節(jié)點(diǎn)*/
    for(i=1;i<12;i++)
    {
        if((toInsert=(node*)malloc(sizeof(node)))==NULL)
        {
            perror("malloc error");
            exit(1);
        }
        toInsert->key=a[i];
        insert(root,toInsert);
    }

    /*中序遍歷*/
    middleSearch(root);
    printf("\n");
    /*先序遍歷*/
    preSearch(root);
    printf("\n");

    /*最大值*/
    maximun(root);
    /*最小值*/
    minimun(root);

    /*查找關(guān)鍵字節(jié)點(diǎn)及其前驅(qū)*/
    x=search(root,6);
    y=successor(x);
    if(y!=NULL)
        printf("節(jié)點(diǎn) 6 后驅(qū) %d\n",y->key);

    x=search(root,3);
    y=successor(x);
    if(y!=NULL)
        printf("節(jié)點(diǎn) 3 后驅(qū) %d\n",y->key);


    x=search(root,13);
    y=successor(x);
    if(y!=NULL)
        printf("節(jié)點(diǎn) 13 后驅(qū) %d\n",y->key);


    x=search(root,23);
    y=successor(x);
    if(y!=NULL)
        printf("節(jié)點(diǎn) 23 后驅(qū) %d\n",y->key);

    /*刪除節(jié)點(diǎn)*/
    printf("before delete the node\n");
    x=search(root,13);

    delete(root,x);
    printf("\nafter delete the node\n");
    
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);

    if((toInsert=(node*)malloc(sizeof(node)))==NULL)
    {
        perror("malloc error");
        exit(1);
    }
    toInsert->key=13;
    insert(root,toInsert);
    printf("\n中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);


    printf("\nbefore delete the node\n");
    x=search(root,16);
    delete(root,x);
    printf("\nafter delete the node\n");
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);

    if((toInsert=(node*)malloc(sizeof(node)))==NULL)
    {
        perror("malloc error");
        exit(1);
    }
    toInsert->key=16;
    insert(root,toInsert);
    printf("\n中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);

    printf("\nbefore delete the node\n");
    x=search(root,5);
    delete(root,x);
    printf("\nafter delete the node\n");
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);
    if((toInsert=(node*)malloc(sizeof(node)))==NULL)
    {
        perror("malloc error");
        exit(1);
    }
    toInsert->key=5;
    insert(root,toInsert);

    printf("\n中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);

    printf("\nbefore delete the node\n");
    x=search(root,15);

    delete(root,x);
    printf("\nafter delete the node\n");
   
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);

    printf("\n");


    printf("before delete the node\n");
    x=search(root,16);

    delete(root,x);
    printf("\nafter delete the node\n");
   
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);
    printf("\n");



    printf("before delete the node\n");
    x=search(root,18);

    delete(root,x);
    printf("\nafter delete the node\n");
   
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);
    printf("\n");

    printf("before delete the node\n");
    x=search(root,20);

    delete(root,x);
    printf("\nafter delete the node\n");
   
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);
    printf("\n");


    printf("before delete the node\n");
    x=search(root,23);

    delete(root,x);
    printf("\nafter delete the node\n");
   
    printf("中序遍歷\n");
    middleSearch(root);
    printf("\n先序遍歷\n");
    preSearch(root);
    printf("\n");
}
 

posted on 2011-03-28 16:15 周強(qiáng) 閱讀(305) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人亚洲| 亚洲国产精品久久久久久女王| 中文在线资源观看网站视频免费不卡 | 日韩视频一区二区三区| 亚洲精品一区二区三区在线观看| 亚洲精品1区| 亚洲精品日韩激情在线电影| 日韩一区二区福利| 香蕉久久久久久久av网站| 久久精品国亚洲| 欧美国产三区| av成人黄色| 久久国产精品亚洲va麻豆| 久久综合久久美利坚合众国| 欧美极品欧美精品欧美视频| 国产精品hd| 在线观看日韩av先锋影音电影院| 国产精品午夜在线| 国产区二精品视| 国产日韩精品视频一区| 欧美人妖在线观看| 欧美日韩国产区| 国产一区二区三区av电影| 亚洲欧洲精品一区二区三区| 亚洲一级特黄| 欧美成人午夜影院| 亚洲午夜小视频| 欧美岛国激情| 国产小视频国产精品| 99精品欧美一区| 久久久久.com| 中文亚洲字幕| 欧美精品999| 精品成人国产在线观看男人呻吟| 亚洲深夜福利网站| 欧美激情视频网站| 欧美专区一区二区三区| 国产精品二区在线观看| 亚洲激情黄色| 久久久国产精品一区二区中文| 亚洲国产精品欧美一二99| 亚洲社区在线观看| 欧美激情久久久久久| 激情欧美国产欧美| 欧美一区二区三区男人的天堂 | 亚洲第一伊人| 午夜精品在线| 国产精品入口夜色视频大尺度 | 亚洲午夜激情网页| 欧美国产高潮xxxx1819| 久久精品国产清高在天天线| 国产精品日韩精品欧美在线 | 国产亚洲精品久| 亚洲欧美另类中文字幕| 日韩系列欧美系列| 欧美日韩成人综合| 日韩性生活视频| 最新日韩中文字幕| 欧美成人精品h版在线观看| 激情文学综合丁香| 久久久www免费人成黑人精品 | 欧美成人免费大片| 久久精品国产清自在天天线| 国内精品免费午夜毛片| 久久久久久噜噜噜久久久精品 | 免费永久网站黄欧美| 国产自产高清不卡| 久久精品国产亚洲高清剧情介绍| 宅男在线国产精品| 国产精品欧美激情| 欧美在线观看一二区| 欧美一级视频精品观看| 国产香蕉久久精品综合网| 久久av最新网址| 久久久久久久久久久一区 | 久久精品国产精品亚洲| 欧美在线国产| 亚洲国产精品高清久久久| 亚洲精美视频| 欧美视频在线视频| 久久精品久久综合| 久久一二三区| 在线亚洲欧美视频| 香蕉久久精品日日躁夜夜躁| 怡红院精品视频| 亚洲欧洲精品一区二区| 国产精品国产| 美女网站久久| 欧美肉体xxxx裸体137大胆| 亚洲视频免费| 国产精品wwwwww| 久热精品视频在线观看一区| 欧美va天堂va视频va在线| 亚洲性图久久| 久久久99爱| 亚洲午夜一区二区| 久久久久久九九九九| 亚洲一区视频在线观看视频| 久久久www免费人成黑人精品| 99精品免费网| 久久精品天堂| 亚洲欧美日韩专区| 欧美成人一区在线| 欧美中在线观看| 欧美精品福利视频| 麻豆av福利av久久av| 国产精品成人国产乱一区| 嫩草成人www欧美| 国产精品入口日韩视频大尺度| 欧美激情视频在线播放| 国产欧美一区二区精品秋霞影院| 亚洲日本激情| 1000精品久久久久久久久| 亚洲综合色自拍一区| 日韩视频不卡| 韩国一区二区在线观看| 99re6这里只有精品| 亚洲国产精品尤物yw在线观看| 亚洲在线中文字幕| 99精品国产在热久久| 免费在线视频一区| 久久综合亚州| 国产综合久久久久久| 亚洲欧美日韩综合一区| 亚洲午夜激情网页| 久久躁日日躁aaaaxxxx| 久久精品人人做人人爽| 香蕉免费一区二区三区在线观看 | 久久久久久久一区二区| 性久久久久久久久久久久| 欧美日韩国产经典色站一区二区三区 | 国产一区二区三区网站 | 欧美一区二区视频网站| 香蕉国产精品偷在线观看不卡| 欧美午夜精品理论片a级大开眼界| 亚洲人成高清| 艳妇臀荡乳欲伦亚洲一区| 欧美激情一区二区三区在线视频观看| 久久中文久久字幕| 激情久久影院| 美女主播视频一区| 亚洲黄网站在线观看| 亚洲精品视频一区| 欧美日韩18| 亚洲视频免费在线| 欧美中文字幕在线| 狠狠做深爱婷婷久久综合一区 | 亚洲成色精品| 亚洲免费av网站| 欧美婷婷六月丁香综合色| 中文一区在线| 久久久久一区二区三区四区| 黄色精品一区| 欧美电影电视剧在线观看| a4yy欧美一区二区三区| 欧美一区二区三区视频在线观看 | 久久国产精品黑丝| 伊人久久综合97精品| 欧美福利网址| 亚洲天堂免费在线观看视频| 欧美在线观看你懂的| 亚洲国产精品ⅴa在线观看| 欧美日韩国产精品自在自线| 亚洲一区二区三区免费观看| 久久久91精品国产一区二区三区 | 久久噜噜噜精品国产亚洲综合| 老**午夜毛片一区二区三区| 91久久精品国产| 国产精品美女久久久久av超清 | 午夜激情综合网| 国产亚洲成精品久久| 欧美国产一区二区三区激情无套| 99国产精品久久| 中文在线资源观看网站视频免费不卡 | 亚洲一区二区成人| 久久亚洲精品网站| 一区二区高清在线| 国产日韩欧美中文| 欧美激情第3页| 先锋亚洲精品| 亚洲精品一区二区三| 久久久久国产精品www| 99视频有精品| 在线观看国产精品淫| 国产精品va在线播放我和闺蜜| 久久一区亚洲| 亚洲欧美在线播放| 亚洲精品国产精品国自产观看| 久久精品在线视频| 国产精品99久久久久久久女警 | 在线观看成人小视频| 国产精品无人区| 欧美日韩国产999| 美国十次成人| 久久久久久久综合日本| 亚洲一区在线观看视频| 亚洲精品在线免费观看视频| 欧美va天堂va视频va在线| 久久aⅴ国产紧身牛仔裤| 亚洲男女自偷自拍|