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

也許二杈樹是很好用的,在插入和查找的時(shí)候時(shí)間復(fù)雜度一般為O(logN),但如果左右子樹失去平衡,也可能達(dá)到O(N)。為了防止這種現(xiàn)象發(fā)生,一種解決辦法是是左右子樹盡量保持平衡,即建立一種平衡有序樹AVL樹。?????
????一棵AVL樹是其每個(gè)結(jié)點(diǎn)的左子樹和右子樹的高度最多相差1的二杈有序樹。空樹的高度定義為-1。
????AVL樹的結(jié)點(diǎn)聲明;
typedef?struct?avlnode
{
????int?height;//比普通二杈有序樹多了一個(gè)高度信息?
????ElemType?data;
????struct?bnode?*lchild,?*rchild;
}?*AvlTree,?*Position;????
//----------AVL樹基本操作------------?------------------------------
AvlTree?MakeEmpty(AvlTree?T);
Position?Find(ElemType?x,?AvlTree?T);
Position?FindMin(AvlTree?T);
Position?FindMax(AvlTree?T);
static?int?Height(Position?P);
AvlTree?Insert(ElemType?x,?AvlTree?T);
AvlTree?Delete(ElemType?x,?AvlTree?T);
ElemType?Retrieve(Position?P);

//----------AVL樹基本操作的算法實(shí)現(xiàn)--------------------
遞歸算法:?
Position?FindMin(AvlTree?T)
{
????if(T==NULL)
????????return?NULL;
????else?if(T->lchild?==?NULL)
????????return?T;
????else
????????return?FindMin(T->lchild);
}

Position?FindMax(AvlTree?T)
{
????if(T==NULL)
????????return?NULL;
????else?if(T->rchild?==?NULL)
????????return?T;
????else
????????return?FindMax(T->rchild);
}
非遞歸算法:
Position?FindMin(AvlTree?T)
{
????if(T!=NULL)
????{
????????while(T->lchild?!=?NULL)
????????????T?=?T->lchild;
????}
????
????return?T;
}

Position?FindMax(AvlTree?T)
{
????if(T!=NULL)
????{
????????while(T->rchild?!=?NULL)
????????????T?=?T->rchild;
????}
????
????return?T;
}
//返回P點(diǎn)的高度?
static?int?Height(Position?P)
{
????if(P==NULL)
????????return?-1;
????else
????????return?P->height;
}
//在對(duì)一棵AVL樹進(jìn)行插入操作后,可能會(huì)破壞它的平衡條件,因此必須對(duì)新的AVL樹進(jìn)行調(diào)整,
這里用到了“單旋轉(zhuǎn)”或“雙旋轉(zhuǎn)”的算法,分別適用于:
單左旋轉(zhuǎn)(SingleRotateWithLeft);對(duì)結(jié)點(diǎn)p的左孩子的左子樹進(jìn)行一次插入?
單右旋轉(zhuǎn)(SingleRotateWithRight);對(duì)結(jié)點(diǎn)p的右孩子的右子樹進(jìn)行一次插入??
雙左旋轉(zhuǎn)(DoubleRotateWithLeft);對(duì)結(jié)點(diǎn)p的左孩子的右子樹進(jìn)行一次插入?
雙右旋轉(zhuǎn)(DoubleRotateWithRight);對(duì)結(jié)點(diǎn)p的右孩子的左子樹進(jìn)行一次插入??
static?Position?SingleRotateWithLeft(Position?K2)
{
????Position?K1;
????
????K1?=?K2->lchild;??//在K2和K1之間進(jìn)行一次單左旋轉(zhuǎn)?
????K2->lchild?=?K1->rchild;
????K1->rchild?=?K2;
????
????K2->height?=?Max(Height(K2->lchild),?Height(K2->rchild))?+?1;
????K1->height?=?Max(Height(K1->lchild),?Height(K1->rchild))?+?1;
????
????return?K1;
}

static?Position?SingleRotateWithRight(Position?K2)
{
????Position?K1;
????
????K1?=?K2->rchild;????//在K2和K1之間進(jìn)行一次單右旋轉(zhuǎn)?
????K2->rchild?=?K1->lchild;
????K1->lchild?=?K2;
????
????K2->height?=?Max(Height(K2->lchild),?Height(K2->rchild))?+?1;
????K1->height?=?Max(Height(K1->lchild),?Height(K1->rchild))?+?1;
????
????return?K1;
}

static?Position?DoubleRotateWithLeft(Position?K3)
{
????K3->lchild?=?SingleRotateWithRight(K3->lchild);?//在K2和K1之間進(jìn)行一次單右旋轉(zhuǎn)?
????
????return?SingleRotateWithLeft(K3);?//在K3和K2之間進(jìn)行一次單左旋轉(zhuǎn)?
}

static?Position?DoubleRotateWithRight(Position?K3)
{
????K3->rchild?=?SingleRotateWithLeft(K3->rchild);?//在K2和K1之間進(jìn)行一次單左旋轉(zhuǎn)?
????
????return?SingleRotateWithRight(K3);//在K3和K2之間進(jìn)行一次單右旋轉(zhuǎn)?
}

//向AVL樹插入結(jié)點(diǎn)的操作?
AvlTree?Insert(float?x,?AvlTree?T)
{
????if(T?==?NULL)
????{
????????T?=?(Position)malloc(sizeof(struct?avlnode));
????????if(T?==?NULL)
????????{
????????????puts("wrong");?
????????????exit(1);
????????}
????????T->data?=?x;??
????????T->height?=?0;
????????T->lchild?=?T->rchild?=?NULL;
????}
????else?if(T->data?==?x)//不做任何插入操作?
????????;
????else?if(T->data?>?x)//把s所指結(jié)點(diǎn)插入到左子樹中
????{
??????????T->lchild?=?Insert(x,?T->lchild);
??????????if(Height(T->lchild)?-?Height(T->rchild)?==?2)?//若平衡被破壞
??????????{
????????????if(x?<?T->lchild->data)?????//若x比T的左孩子小,對(duì)T單左旋轉(zhuǎn)??
????????????????T?=?SingleRotateWithLeft(T);
????????????else?????????????????????????//否則,對(duì)T雙左旋轉(zhuǎn)???
????????????????T?=?DoubleRotateWithLeft(T);
????????}
????}
????else??????//把s所指結(jié)點(diǎn)插入到右子樹中
????{
??????????T->rchild?=?Insert(x,?T->rchild);
??????????if(Height(T->rchild)?-?Height(T->lchild)?==?2)
??????????{
????????????if(x?>?T->rchild->data)????//若x比T的右孩子大,對(duì)T單右旋轉(zhuǎn)??
????????????????T?=?SingleRotateWithRight(T);
????????????else????????????????????????//否則,對(duì)T雙右旋轉(zhuǎn)???
????????????????T?=?DoubleRotateWithRight(T);
????????}
????}
????T->height?=?Max(Height(T->lchild),?Height(T->rchild))?+?1;
????
????return?T;???
}
int?Max(int?a,?int?b)
{
????if(a?>?b)
????????return?a;
????else
????????return?b;
}
還有一種AVL樹,它的結(jié)構(gòu)中不包含高度特征,但包含一個(gè)平衡因子bf,用來(lái)判斷結(jié)點(diǎn)的平衡性,若左孩子比右孩子高,則bf==1;否則,bf==-1;若左右相等則bf==0。
????AVL樹的結(jié)點(diǎn)聲明;
enum??BALANCE{LH?=?1,?EH?=?0,?RH?=?-1};
typedef?struct?avlnode
{
????BALANCE?bf;//比普通二杈有序樹多了一個(gè)平衡因子信息
????ElemType?data;
????struct?avlnode?*lchild,?*rchild;
}?*AvlTree,?*Position;
//----------AVL樹基本操作------------?------------------------------
AvlTree?MakeEmpty(AvlTree?T);
Position?Find(ElemType?x,?AvlTree?T);
Position?FindMin(AvlTree?T);
Position?FindMax(AvlTree?T);
AvlTree?Insert(ElemType?x,?AvlTree?T);
AvlTree?Delete(ElemType?x,?AvlTree?T);
ElemType?Retrieve(Position?P);

//----------AVL樹基本操作的算法實(shí)現(xiàn)--------------------

//在對(duì)一棵AVL樹進(jìn)行插入操作后,可能會(huì)破壞它的平衡條件,因此必須對(duì)新的AVL樹進(jìn)行調(diào)整,
這里用到了“單旋轉(zhuǎn)”或“雙旋轉(zhuǎn)”的算法,分別適用于:
單左旋轉(zhuǎn)(SingleRotateWithLeft);對(duì)結(jié)點(diǎn)p的左孩子的左子樹進(jìn)行一次插入
單右旋轉(zhuǎn)(SingleRotateWithRight);對(duì)結(jié)點(diǎn)p的右孩子的右子樹進(jìn)行一次插入
雙左旋轉(zhuǎn)(DoubleRotateWithLeft);對(duì)結(jié)點(diǎn)p的左孩子的右子樹進(jìn)行一次插入
雙右旋轉(zhuǎn)(DoubleRotateWithRight);對(duì)結(jié)點(diǎn)p的右孩子的左子樹進(jìn)行一次插入
Position?SingleRotateWithLeft(Position?K2)
{
????Position?K1;

????K1?=?K2->lchild;??//在K2和K1之間進(jìn)行一次單左旋轉(zhuǎn)
????K2->lchild?=?K1->rchild;
????K1->rchild?=?K2;

????return?K1;
}

Position?SingleRotateWithRight(Position?K2)
{
????Position?K1;

????K1?=?K2->rchild;????//在K2和K1之間進(jìn)行一次單右旋轉(zhuǎn)
????K2->rchild?=?K1->lchild;
????K1->lchild?=?K2;

????return?K1;
}

Position?DoubleRotateWithLeft(Position?K3)
{
????K3->lchild?=?SingleRotateWithRight(K3->lchild);?//在K2和K1之間進(jìn)行一次單右旋轉(zhuǎn)

????return?SingleRotateWithLeft(K3);?//在K3和K2之間進(jìn)行一次單左旋轉(zhuǎn)
}

Position?DoubleRotateWithRight(Position?K3)
{
????K3->rchild?=?SingleRotateWithLeft(K3->rchild);?//在K2和K1之間進(jìn)行一次單左旋轉(zhuǎn)

????return?SingleRotateWithRight(K3);//在K3和K2之間進(jìn)行一次單右旋轉(zhuǎn)
}

AvlTree?LeftBalance(AvlTree?T)?//左平衡處理
{
??????AvlTree?lT?=?T->lchild;
??????switch?(lT->bf)?//檢查左樹的平衡度,并做相應(yīng)處理
??????{
????????????case?LH?:???T?=?SingleRotateWithLeft(T);?//若新結(jié)點(diǎn)插入在T的左孩子的左子樹上,對(duì)T單左旋轉(zhuǎn)
????????????????????????T->bf?=?lT->bf?=?EH;???//重新設(shè)置平衡度
????????????????????????break;
????????????case?RH?:???AvlTree?rT?=?lT->rchild;//若新結(jié)點(diǎn)插入在T的左孩子的右子樹上,對(duì)T雙左旋轉(zhuǎn),并重新設(shè)置平衡度
????????????????????????switch?(rT->bf)
????????????????????????{
??????????????????????????????case?LH?:???T->bf?=?RH;
??????????????????????????????????????????lT->bf?=?EH;
??????????????????????????????????????????break;
??????????????????????????????case?EH?:???T->bf?=?lT->bf?=?EH;?//我感覺這種情況應(yīng)該不會(huì)出現(xiàn)
??????????????????????????????????????????break;
??????????????????????????????case?RH?:???T->bf?=?EH;
??????????????????????????????????????????lT->bf?=?LH;
??????????????????????????????????????????break
????????????????????????}
????????????????????????rT->bf?=?EH;
????????????????????????T?=?DoubleRotateWithLeft(T);
????????????????????????break;
??????}
??????return?T;
}

AvlTree?RightBalance(AvlTree?T)?//右平衡處理
{
??????AvlTree?rT?=?T->rchild;
??????switch?(rT->bf)?//檢查右樹的平衡度,并做相應(yīng)處理
??????{
????????????case?LH?:???T?=?SingleRotateWithRight(T);?//若新結(jié)點(diǎn)插入在T的右孩子的右子樹上,對(duì)T單右旋轉(zhuǎn)
????????????????????????T->bf?=?rT->bf?=?EH;???//重新設(shè)置平衡度
????????????????????????break;
????????????case?RH?:???AvlTree?lT?=?rT->lchild;//若新結(jié)點(diǎn)插入在T的右孩子的左子樹上,對(duì)T雙右旋轉(zhuǎn),并重新設(shè)置平衡度
????????????????????????switch?(lT->bf)
????????????????????????{
??????????????????????????????case?LH?:???T->bf?=?EH;
??????????????????????????????????????????rT->bf?=?RH;
??????????????????????????????????????????break;
??????????????????????????????case?EH?:???T->bf?=?rT->bf?=?EH;?//我感覺這種情況應(yīng)該不會(huì)出現(xiàn)
??????????????????????????????????????????break;
??????????????????????????????case?RH?:???T->bf?=?LH;
??????????????????????????????????????????rT->bf?=?EH;
??????????????????????????????????????????break
????????????????????????}
????????????????????????lT->bf?=?EH;
????????????????????????T?=?DoubleRotateWithRight(T);
????????????????????????break;
??????}
??????return?T;
}

//向AVL樹插入結(jié)點(diǎn)的操作
AvlTree?Insert(ElemType?x,?AvlTree?T,?bool?&?taller)
{
????if(T?==?NULL)
????{
????????T?=?(Position)malloc(sizeof(struct?avlnode));
????????if(T?==?NULL)
????????{
????????????puts("wrong");
????????????exit(1);
????????}
????????T->data?=?x;
????????T->lchild?=?T->rchild?=?NULL;
????????T->bf?=?EH;
????????taller?=?true;?//插入新結(jié)點(diǎn),樹“長(zhǎng)高”,置taller為真值
????}
????else?if(T->data?==?x)//不做任何插入操作
????????taller?=?false;?//樹未長(zhǎng)高,置taller為假值
????else?if(T->data?>?x)//把x插入到左子樹中
????{
??????????T->lchild?=?Insert(x,?T->lchild,?taller);
??????????if?(taller)//已經(jīng)插入左子樹,且樹“長(zhǎng)高”,需要檢查平衡度,并做相應(yīng)處理
??????????{
??????????????????switch(T->bf)
??????????????????{
????????????????????????case?LH?:???T?=?LeftBalance(T);//原本左樹高于右樹,需做左平衡處理,樹高不變
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
????????????????????????case?EH?:???T->bf?=?LH;//原本左右等高,現(xiàn)在左高于右,且樹“長(zhǎng)高”
????????????????????????????????????taller?=?true;
????????????????????????????????????break;
????????????????????????case?RH?:???T->bf?=?EH;?//原本右樹高于左樹,現(xiàn)在左右等高,樹高不變
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
??????????????????}
????????????}
????}
????else??????//把x插入到右子樹中,仿照處理左樹的方法處理
????{
????????????T->rchild?=?Insert(x,?T->rchild,?taller);
??????????if?(taller)
??????????{
??????????????????switch(T->bf)
??????????????????{
????????????????????????case?LH?:???T->bf?=?EH;
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
????????????????????????case?EH?:???T->bf?=?RH;
????????????????????????????????????taller?=?true;
????????????????????????????????????break;
????????????????????????case?RH?:???T?=?RightBalance(T);
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
??????????????????}
????????????}
????}

????return?T;
}
AVL樹應(yīng)用示例:
?/*輸入一組數(shù),存儲(chǔ)到AVL樹中,并進(jìn)行輸出*/
#include?<iostream>
using?namespace?std;

#define?MAX?100
enum??BALANCE{LH?=?1,?EH?=?0,?RH?=?-1};
typedef?struct?avlnode
{
????BALANCE?bf;//比普通二杈有序樹多了一個(gè)平衡因子信息
????int?data;
????struct?avlnode?*lchild,?*rchild;
}?*AvlTree,?*Position;

int?Input(int?a[]);//輸入數(shù)據(jù)到數(shù)組,未排序
void?Print(const?int?a[],?int?len);?//輸入未排序的原始數(shù)據(jù)
AvlTree?Sort(AvlTree?A,?const?int?a[],?int?len);?//對(duì)數(shù)據(jù)進(jìn)行排序
AvlTree?Insert(int?x,?AvlTree?T,?bool?&?taller);?//把數(shù)據(jù)存儲(chǔ)到AVL樹中
Position?SingleRotateWithLeft(Position?K2);?//單左旋轉(zhuǎn)
Position?SingleRotateWithRight(Position?K2);?//單右旋轉(zhuǎn)
Position?DoubleRotateWithLeft(Position?K3);//雙左旋轉(zhuǎn)
Position?DoubleRotateWithRight(Position?K3);//雙右旋轉(zhuǎn)
AvlTree?LeftBalance(AvlTree?T);//?左平衡處理
AvlTree?RightBalance(AvlTree?T);?//右平衡處理
void?inorder(const?AvlTree?bt);?//中序遍歷AVL樹
void?PrintBT(AvlTree?bt);?//輸出二杈樹

int?main(void)
{
????int?a[MAX]={0};
????int?len;
????AvlTree?A=NULL;

????len?=?Input(a);
????Print(a,?len);
????printf("\n");
????A?=?Sort(A,?a,?len);
????PrintBT(A);
????printf("\n");
????inorder(A);
????system("pause");
??????return?0;
}
int?Input(int?a[])
{
????int?i=0;

????do{
????????a[i++]?=?rand()%1000;//輸入隨機(jī)數(shù)
????}?while(i<MAX);
????return?i;
}
void?Print(const?int?a[],?int?len)
{
????int?i;

????for(i=0;?i<len;?i++)
????????printf("%d\t",?a[i]);
}
AvlTree?Sort(AvlTree?A,?const?int?a[],?int?len)
{
????int?i;
????bool?taller?=?false;

????for(i=0;?i<len;?i++)
?????????A?=?Insert(a[i],?A,?taller);
????return?A;
}
void?inorder(const?AvlTree?bt)
{
????AvlTree?p=bt,?stack[MAX];//p表示當(dāng)前結(jié)點(diǎn),棧stack[]用來(lái)存儲(chǔ)結(jié)點(diǎn)
????int?top=-1;

????do
????{
????????while(p?!=?NULL)//先處理結(jié)點(diǎn)的左孩子結(jié)點(diǎn),把所有左孩子依次入棧
????????{
????????????stack[++top]?=?p;
????????????p?=?p->lchild;
????????}
????????if(top?>=?0)?//所有左孩子處理完畢后
????????{
????????????p?=?stack[top--];//棧頂元素出棧
????????????printf("%d\t",?p->data);?//輸出該結(jié)點(diǎn)
????????????p?=?p->rchild;?//處理其右孩子結(jié)點(diǎn)
????????}
????}?while((p?!=?NULL)||(top?>=?0));
}

//向AVL樹插入結(jié)點(diǎn)的操作
AvlTree?Insert(int?x,?AvlTree?T,?bool?&?taller)
{
????if(T?==?NULL)
????{
????????T?=?(Position)malloc(sizeof(struct?avlnode));
????????if(T?==?NULL)
????????{
????????????puts("wrong");
????????????exit(1);
????????}
????????T->data?=?x;
????????T->lchild?=?T->rchild?=?NULL;
????????T->bf?=?EH;
????????taller?=?true;?//插入新結(jié)點(diǎn),樹“長(zhǎng)高”,置taller為真值
????}
????else?if(T->data?==?x)//不做任何插入操作
????????taller?=?false;?//樹未長(zhǎng)高,置taller為假值
????else?if(T->data?>?x)//把x插入到左子樹中
????{
??????????T->lchild?=?Insert(x,?T->lchild,?taller);
??????????if?(taller)//已經(jīng)插入左子樹,且樹“長(zhǎng)高”,需要檢查平衡度,并做相應(yīng)處理
??????????{
??????????????????switch(T->bf)
??????????????????{
????????????????????????case?LH?:???T?=?LeftBalance(T);//原本左樹高于右樹,需做左平衡處理,樹高不變
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
????????????????????????case?EH?:???T->bf?=?LH;//原本左右等高,現(xiàn)在左高于右,且樹“長(zhǎng)高”
????????????????????????????????????taller?=?true;
????????????????????????????????????break;
????????????????????????case?RH?:???T->bf?=?EH;?//原本右樹高于左樹,現(xiàn)在左右等高,樹高不變
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
??????????????????}
????????????}
????}
????else??????//把x插入到右子樹中,仿照處理左樹的方法處理
????{
????????????T->rchild?=?Insert(x,?T->rchild,?taller);
??????????if?(taller)
??????????{
??????????????????switch(T->bf)
??????????????????{
????????????????????????case?LH?:???T->bf?=?EH;
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
????????????????????????case?EH?:???T->bf?=?RH;
????????????????????????????????????taller?=?true;
????????????????????????????????????break;
????????????????????????case?RH?:???T?=?RightBalance(T);
????????????????????????????????????taller?=?false;
????????????????????????????????????break;
??????????????????}
????????????}
????}

????return?T;
}

Position?SingleRotateWithLeft(Position?K2)
{
????Position?K1;

????K1?=?K2->lchild;??//在K2和K1之間進(jìn)行一次單左旋轉(zhuǎn)
????K2->lchild?=?K1->rchild;
????K1->rchild?=?K2;

????return?K1;
}

Position?SingleRotateWithRight(Position?K2)
{
????Position?K1;

????K1?=?K2->rchild;????//在K2和K1之間進(jìn)行一次單右旋轉(zhuǎn)
????K2->rchild?=?K1->lchild;
????K1->lchild?=?K2;

????return?K1;
}

Position?DoubleRotateWithLeft(Position?K3)
{
????K3->lchild?=?SingleRotateWithRight(K3->lchild);?//在K2和K1之間進(jìn)行一次單右旋轉(zhuǎn)

????return?SingleRotateWithLeft(K3);?//在K3和K2之間進(jìn)行一次單左旋轉(zhuǎn)
}

Position?DoubleRotateWithRight(Position?K3)
{
????K3->rchild?=?SingleRotateWithLeft(K3->rchild);?//在K2和K1之間進(jìn)行一次單左旋轉(zhuǎn)

????return?SingleRotateWithRight(K3);//在K3和K2之間進(jìn)行一次單右旋轉(zhuǎn)
}

AvlTree?LeftBalance(AvlTree?T)?//左平衡處理
{
??????AvlTree?lT?=?T->lchild;
??????switch?(lT->bf)?//檢查左樹的平衡度,并做相應(yīng)處理
??????{
????????????case?LH?:???T?=?SingleRotateWithLeft(T);?//若新結(jié)點(diǎn)插入在T的左孩子的左子樹上,對(duì)T單左旋轉(zhuǎn)
????????????????????????T->bf?=?lT->bf?=?EH;???//重新設(shè)置平衡度
????????????????????????break;
????????????case?RH?:???AvlTree?rT?=?lT->rchild;//若新結(jié)點(diǎn)插入在T的左孩子的右子樹上,對(duì)T雙左旋轉(zhuǎn),并重新設(shè)置平衡度
????????????????????????switch?(rT->bf)
????????????????????????{
??????????????????????????????case?LH?:???T->bf?=?RH;
??????????????????????????????????????????lT->bf?=?EH;
??????????????????????????????????????????break;
??????????????????????????????case?EH?:???T->bf?=?lT->bf?=?EH;?//我感覺這種情況應(yīng)該不會(huì)出現(xiàn)
??????????????????????????????????????????break;
??????????????????????????????case?RH?:???T->bf?=?EH;
??????????????????????????????????????????lT->bf?=?LH;
??????????????????????????????????????????break;
????????????????????????}
????????????????????????rT->bf?=?EH;
????????????????????????T?=?DoubleRotateWithLeft(T);
????????????????????????break;
??????}
??????return?T;
}

AvlTree?RightBalance(AvlTree?T)?//右平衡處理
{
??????AvlTree?rT?=?T->rchild;
??????switch?(rT->bf)?//檢查右樹的平衡度,并做相應(yīng)處理
??????{
????????????case?RH?:???T?=?SingleRotateWithRight(T);?//若新結(jié)點(diǎn)插入在T的右孩子的右子樹上,對(duì)T單右旋轉(zhuǎn)
????????????????????????T->bf?=?rT->bf?=?EH;???//重新設(shè)置平衡度
????????????????????????break;
????????????case?LH?:???AvlTree?lT?=?rT->lchild;//若新結(jié)點(diǎn)插入在T的右孩子的左子樹上,對(duì)T雙右旋轉(zhuǎn),并重新設(shè)置平衡度
????????????????????????switch?(lT->bf)
????????????????????????{
??????????????????????????????case?LH?:???T->bf?=?EH;
??????????????????????????????????????????rT->bf?=?RH;
??????????????????????????????????????????break;
??????????????????????????????case?EH?:???T->bf?=?rT->bf?=?EH;?//我感覺這種情況應(yīng)該不會(huì)出現(xiàn)
??????????????????????????????????????????break;
??????????????????????????????case?RH?:???T->bf?=?LH;
??????????????????????????????????????????rT->bf?=?EH;
??????????????????????????????????????????break;
????????????????????????}
????????????????????????lT->bf?=?EH;
????????????????????????T?=?DoubleRotateWithRight(T);
????????????????????????break;
??????}
??????return?T;
}

void?PrintBT(AvlTree?bt)
{
????if(bt?!=?NULL)
????{
????????printf("%d",?bt->data);
????????if(bt->lchild!=NULL?||?bt->rchild!=NULL)
????????{
????????????printf("(");
????????????PrintBT(bt->lchild);
????????????if(bt->rchild!=NULL)
????????????????printf(",");
????????????PrintBT(bt->rchild);
????????????printf(")");
????????}
????}
}
Posted on 2006-06-04 16:53 夢(mèng)想飛揚(yáng) 閱讀(1423) 評(píng)論(4)  編輯 收藏 引用

Feedback

# re: 平衡有序樹AVL樹之兩種思路  回復(fù)  更多評(píng)論   

2006-06-05 19:27 by TH
你一定是一個(gè)算法高手. 呵呵,收集你很多文章 .
關(guān)注

# re: 平衡有序樹AVL樹之兩種思路  回復(fù)  更多評(píng)論   

2007-07-30 16:07 by ll
沒看到有delete的實(shí)現(xiàn)。

# re: 平衡有序樹AVL樹之兩種思路  回復(fù)  更多評(píng)論   

2007-07-31 15:27 by ??
找到離插入點(diǎn)最近的不平衡節(jié)點(diǎn),然后修改該點(diǎn)到插入點(diǎn)的路徑(不包括這兩點(diǎn))上的balance factor,再作4種rotation處理,比之遞歸、彈棧都要高效。

# re: 平衡有序樹AVL樹之兩種思路  回復(fù)  更多評(píng)論   

2008-01-20 22:10 by 關(guān)注
不錯(cuò)!!

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            先锋影音久久久| 这里只有精品丝袜| 欧美色中文字幕| 日韩午夜在线| 亚洲自拍偷拍色片视频| 欧美偷拍另类| 午夜精品免费视频| 久久久视频精品| 99pao成人国产永久免费视频| 久久精品99久久香蕉国产色戒| 久久久水蜜桃av免费网站| 亚洲国内自拍| 亚洲精品永久免费| 亚洲区国产区| 欧美日韩国产成人在线91| 国产综合久久久久久| 久久综合九色综合久99| 欧美日韩视频在线一区二区| 欧美影视一区| 久久蜜桃资源一区二区老牛 | 校园春色综合网| 久久久久久精| 亚洲人成在线播放网站岛国| 国产精品免费久久久久久| 久久久国产精品一区二区中文| 国产一区二区三区在线观看视频 | 日韩亚洲欧美一区二区三区| 香港久久久电影| 亚洲日韩欧美视频一区| 国产一区二区三区久久 | 亚洲美女在线国产| 国产在线一区二区三区四区| 欧美激情 亚洲a∨综合| 欧美在线观看天堂一区二区三区| 日韩图片一区| 日韩视频不卡| 日韩一区二区精品视频| 亚洲国产日韩在线一区模特| 久久久噜久噜久久综合| 小黄鸭精品密入口导航| 艳女tv在线观看国产一区| 亚洲国产精品久久久久秋霞蜜臀| 99热在这里有精品免费| 欧美一区二区视频在线观看| 日韩午夜av电影| 欧美激情亚洲综合一区| 久久亚洲一区二区三区四区| 亚洲综合日韩在线| 一区二区三区三区在线| 亚洲精品美女在线观看| 亚洲国产精品成人一区二区| 黄色在线一区| 狠狠色香婷婷久久亚洲精品| 国产精品一区二区女厕厕| 欧美四级伦理在线| 欧美日韩精品伦理作品在线免费观看| 美女视频一区免费观看| 麻豆精品在线观看| 麻豆国产精品777777在线| 久久久精品网| 欧美成人伊人久久综合网| 欧美电影在线播放| 欧美精品二区| 欧美性色综合| 国产一区二区三区观看| 亚洲国产欧美一区二区三区同亚洲 | 中文一区二区| 亚洲一区二区视频在线观看| 亚洲欧美视频在线| 久久国产精品一区二区三区| 久久久久.com| 欧美精品免费观看二区| 欧美午夜视频| 在线观看日韩国产| 99国产精品久久久久老师| 亚洲免费视频网站| 久久久高清一区二区三区| 美女999久久久精品视频| 亚洲国产精品一区二区久| 一本大道av伊人久久综合| 亚洲欧美日韩国产成人| 久久免费视频一区| 欧美日韩一区二区三区在线 | 在线亚洲精品福利网址导航| 欧美在线观看视频| 欧美美女bbbb| 国产在线一区二区三区四区| 99爱精品视频| 亚洲日本中文| 欧美日韩欧美一区二区| 国产精品久久久久aaaa九色| 国产精品系列在线| 亚洲高清视频在线观看| 9人人澡人人爽人人精品| 久久激情一区| 亚洲免费激情| 你懂的视频欧美| 国产日韩精品入口| 亚洲毛片播放| 久久精品一区| 国产精品99久久99久久久二8| 久久一区亚洲| 国产私拍一区| 一区二区三区欧美在线| 欧美激情1区| 欧美制服丝袜| 国产精品视频最多的网站| 亚洲日韩第九十九页| 久久免费偷拍视频| 亚洲欧美日韩国产精品| 欧美三级中文字幕在线观看| 91久久精品国产| 久久久蜜桃一区二区人| 亚洲愉拍自拍另类高清精品| 欧美凹凸一区二区三区视频| 国产一区导航| 亚洲欧美日韩综合国产aⅴ| 欧美高清在线视频| 久久久精品日韩欧美| 国产亚洲一区二区在线观看| 亚洲欧美另类中文字幕| 日韩视频专区| 欧美亚男人的天堂| 在线综合亚洲欧美在线视频| 欧美激情国产高清| 久久婷婷国产综合精品青草 | 欧美日韩一区二区三区免费| 亚洲精品视频免费观看| 欧美激情亚洲激情| 麻豆成人在线观看| 亚洲黄一区二区三区| 欧美黄在线观看| 欧美顶级艳妇交换群宴| 亚洲精品三级| 日韩视频一区二区三区在线播放免费观看 | 亚洲在线视频观看| 国产乱码精品一区二区三区五月婷| 亚洲国内精品在线| 亚洲日本视频| 欧美日韩麻豆| 性视频1819p久久| 欧美一二区视频| 亚洲免费av网站| 午夜免费电影一区在线观看| 国产欧美一区二区在线观看| 久久国产精品第一页| 亚洲精品极品| 国产精品青草综合久久久久99 | 亚洲午夜日本在线观看| 亚洲色诱最新| 激情校园亚洲| 亚洲国产日韩在线一区模特| 欧美日韩一区不卡| 欧美中文字幕| 媚黑女一区二区| 国产精品午夜在线| 久久久五月婷婷| 欧美护士18xxxxhd| 午夜性色一区二区三区免费视频 | 欧美剧在线免费观看网站| 亚洲最新视频在线| 午夜精彩国产免费不卡不顿大片| 国产视频在线观看一区二区三区 | 欧美成人按摩| 国产精品久久久久婷婷| 女人色偷偷aa久久天堂| 欧美日韩国产小视频| 亚洲欧美激情视频| 久久精品国产免费看久久精品| 99在线|亚洲一区二区| 亚洲自拍偷拍网址| 最新成人在线| 欧美一区二区三区免费在线看| 91久久精品网| 午夜在线电影亚洲一区| 亚洲精品视频中文字幕| 久久精品观看| 亚洲欧美影院| 欧美日本高清| 欧美大成色www永久网站婷| 国产精品视频xxxx| 亚洲片国产一区一级在线观看| 国产精品久久久久久影院8一贰佰| 欧美**字幕| 国产日韩精品在线观看| 夜夜嗨av一区二区三区四季av| 在线成人黄色| 欧美在线观看一区| 午夜久久99| 欧美婷婷六月丁香综合色| 欧美韩日一区| 亚洲大片免费看| 久久人人爽爽爽人久久久| 午夜精品在线看| 国产精品久久福利| 亚洲视频福利| 亚洲综合日本| 国产精品v欧美精品∨日韩| 亚洲精品韩国| 一区二区三区**美女毛片|