平衡二叉树AVL

平衡二叉树的操作:查找,打印,插入,删除(插入删除为重点)
参考http://blog.csdn.net/sysu_arui/article/details/7897017
#include<stdio.h>
#include<stdlib.h>
#define LH 1
#define EH 0
#define RH -1
typedef struct BSTNode{
int data;
int bf;
struct BSTNode lchild,rchild;
}BSTNode,*BSTree;
int Search(BSTree T,int key,BSTree &p)
{
p=NULL;
if (!T) return 0;
else if(T->data==key){
p=T;
}
else if(T->data>key){
Search(T->lchild,key,p);
}
else if(T->data<key){
Search(T->rchild,key,p);
}
return 1;
}
void PrintSearch(BSTree T,int key)
{
BSTree p;
Search(T,key,p);
if(p){
printf("the data is %d\n",p->data);
printf("the balance factor is %d",p->bf);
if(p->lchild)printf("the left child's data is %d\n",p->lchild->data);
else printf("no left child\n");
if(p->rchild)printf("the right child's data is %d\n",p->rchild->data);
else printf("no right child\n");
}
else{
printf("no such key in AVLTree\n");
}
}
void InOrder(BSTree T,int d)
{
if(T){
InOrder(T->rchild,d+1);
for(int i=0;i<d;i++) printf(" ");
printf("%d\n",T->data);
InOrder(T->lchild,d+1);
}
}
void Print(BSTree T)
{
InOrder(T,0);
}
void R_Rotate(BSTree &T)
{
BSTree lc=T->lchild;
T->lchild=lc->rchild;
lc->rchild=T;
T=lc;
}
void L_Rotate(BSTree &T)
{
BSTree rc=T->rchild;
T->rchild=rc->lchild;
rc->lchild=T;
T=rc;
}
void LeftBalance(BSTree &T)
{
BSTree lc=T->lchild;
switch(lc->bf){
case LH:T->bf=lc->bf=EH;R_Rotate(T);break;
case EH:T->bf=LH;lc->bf=RH;R_Rotate(T);break;
case RH:
BSTree rd=lc->rchild;
switch(rd->bf){
case LH:lc->bf=EH;T->bf=RH;break;
case EH:lc->bf=T->bf=EH;break;
case RH:lc->bf=LH;T->bf=EH;break;
}
rd->bf=EH;
L_Rotate(T->lchild);
R_Rotate(T);
}
}
void RightBalance(BSTree &T)
{
BSTree rc=T->rchild;
switch(rc->bf){
case RH:T->bf=rc->bf=EH;L_Rotate(T);break;
case EH:T->bf=RH;rc->bf=LH;L_Rotate(T);break;
case LH:
BSTree ld=rc->lchild;
switch(ld->bf){
case RH:T->bf=LH;rc->bf=EH;break;
case EH:T->bf=rc->bf=EH;break;
case LH:rc->bf=RH;T->bf=EH;break;
}
ld->bf=EH;
R_Rotate(T->rchild);
L_Rotate(T);
}
}
int InsertAVL(BSTree &T,int e,bool &taller)
{
if(!T){
T=(BSTree)malloc(sizeof(BSTNode));
T->data=e;
T->lchild=T->rchild=NULL;
T->bf=EH;
taller=true;
}
else{
if(e==T->data){
taller=false;
return 0;
}
if(e<T->data){
if(!InsertAVL(T->lchild,e,taller)){
return 0;
}
if(taller){
switch(T->bf){
case LH:LeftBalance(T);taller=false;break;
case EH:T->bf=1;taller=true;break;
case RH:T->bf=0;taller=false;break;
}
}
}
else{
if(!InsertAVL(T->rchild,e,taller)){
return 0;
}
if(taller){
switch(T->bf){
case LH:T->bf=EH;taller=false;break;
case EH:T->bf=RH;taller=true;break;
case RH:RightBalance(T);taller=false;break;
}
}
}
}
return 1;
}

bool deleteAVL(BSTree &t,int  key, bool& shorter)
{
    if(t == NULL)   return false; 
    else if(key==t->data)     
    {
        BSTree q = NULL;
        if(t->lchild == NULL)    
        {
            q = t;
            t = t->rchild;  
            delete q;
            shorter = true;
        }
        else if(t->rchild == NULL) 
        {
            q = t;
            t = t->lchild;
            delete q;
            shorter = true;
        }
        else                     
        {
            q = t->lchild;
            while(q->rchild)
            {
                q = q->rchild;
            }
            t->data = q->data;
            deleteAVL(t->lchild, key, shorter); 
        }
    }
    else if(key<t->data)    
    {
        if(!deleteAVL(t->lchild, key, shorter))  return false;
        if(shorter)
        {
            switch(t->bf)
            {
                case LH:  t->bf = EH;shorter = true;break;
                case EH: t->bf = RH; shorter = false;   break;
                case RH:  RightBalance(t); 
                    if(t->rchild->bf == EH) shorter = false;
                    else shorter = true;
                    break;
            }
        }
    }
    else                           
    {
        if(!deleteAVL(t->rchild, key, shorter)) return false;
        if(shorter)
        {
            switch(t->bf)
            {
                case LH:
                    LeftBalance(t);     
                    if(t->lchild->bf == EH)
                        shorter = false;
                    else
                        shorter = true;
                    break;
                case EH:
                    t->bf = LH;
                    shorter = false;
                    break;
                case RH:
                    t->bf = EH;
                    shorter = true;
                    break;
            }
        }
    }
    return true;
}
int main()
{
    bool taller=false,shorter=false;
    BSTree T=NULL;
    while(true)
    {
        int option;
        int s;
        printf(">>>>>\n");
        printf("1:Print\n2:Search\n3:Insert\n4:Delete\n5:exit\n");
        printf("<<<<<\n\n");
        scanf("%d",&option);
        switch(option){
            case 1: printf("the tree is following:\n");Print(T);break;
            case 2: printf("input the number you want to search:\n");
                    scanf("%d",&s);
                    PrintSearch(T,s);
                    break;
            case 3: printf("input the number you want to insert\n");
                    scanf("%d",&s);
                    InsertAVL(T,s,taller);
                    printf("after insert\n");
                    Print(T);
                    break;
            case 4: printf("input the number you want to delet\n");
                    scanf("%d",&s);
                    deleteAVL(T,s,shorter);
                    printf("after delete\n");
                    Print(T);
                    break;
            case 5: exit(0);
            default: printf("input is wrong,again.\n");
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容