亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

平衡二叉樹的實(shí)現(xiàn)實(shí)例

 更新時(shí)間:2014年02月10日 15:26:06   作者:  
這篇文章主要介紹了平衡二叉樹的實(shí)現(xiàn)實(shí)例,需要的朋友可以參考下

復(fù)制代碼 代碼如下:

/*
首先平衡二叉樹是一個(gè)二叉排序樹;
其基本思想是:
在構(gòu)建二叉排序樹的過(guò)程中,當(dāng)每插入一個(gè)節(jié)點(diǎn)時(shí),
先檢查是否因?yàn)椴迦攵茐牧藰涞钠胶庑?,若是?BR>找出最小不平衡樹,進(jìn)行適應(yīng)的旋轉(zhuǎn),使之成為新的平衡二叉樹。
*/
#include<cstdio>
#include<cstdlib>
#define LH 1
#define EH 0
#define RH -1

using namespace std;

typedef struct BTNode
{
 int data;
 int BF;//平衡因子(balance factor)
 struct BTNode *lchild,*rchild;
}BTNode,*BTree;

void R_Rotate(BTree *p)//以p為根節(jié)點(diǎn)的二叉排序樹進(jìn)行右旋轉(zhuǎn)
{
 BTree L;
 L=(*p)->lchild;
 (*p)->lchild=L->rchild;
 L->rchild=(*p);
 *p=L;//p指向新的根節(jié)點(diǎn)
}

void L_Rotate(BTree *p)//以p為根節(jié)點(diǎn)的二叉排序樹進(jìn)行左旋轉(zhuǎn)
{
 BTree R;
 R=(*p)->rchild;
 (*p)->rchild=R->lchild;
 R->lchild=(*p);
 *p=R;
}

void LeftBalance(BTree *T)
{
 BTree L,Lr;
 L=(*T)->lchild;
 switch(L->BF)
 {
  //檢查T的左子樹平衡度,并作相應(yīng)的平衡處理
  case LH://新節(jié)點(diǎn)插入在T的左孩子的左子樹上,做單右旋處理
   (*T)->BF=L->BF=EH;
   R_Rotate(T);
   break;
  case RH://新插入節(jié)點(diǎn)在T的左孩子的右子樹上,做雙旋處理
   Lr=L->rchild;
   switch(Lr->BF)
   {
    case LH:
     (*T)->BF=RH;
     L->BF=EH;
     break;
    case EH:
     (*T)->BF=L->BF=EH;
     break;
    case RH:
     (*T)->BF=EH;
     L->BF=LH;
     break;
   }
   Lr->BF=EH;
   L_Rotate(&(*T)->lchild);
   R_Rotate(T);
 }
}

void RightBalance(BTree *T)
{
 BTree R,Rl;
 R=(*T)->rchild;
 switch(R->BF)
 {
  case RH://新節(jié)點(diǎn)插在T的右孩子的右子樹上,要做單左旋處理
   (*T)->BF=R->BF=EH;
   L_Rotate(T);
   break;
  case LH://新節(jié)點(diǎn)插在T的右孩子的左子樹上,要做雙旋處理
   Rl=R->lchild;
   switch(Rl->BF)
   {
    case LH:
     (*T)->BF=EH;
     R->BF=RH;
     break;
    case EH:
     (*T)->BF=R->BF=EH;
     break;
    case RH:
     (*T)->BF=LH;
     R->BF=EH;
     break;
   }
   Rl->BF=EH;
   R_Rotate(&(*T)->rchild);
   L_Rotate(T);
 }
}

bool InsertAVL(BTree *T,int e,bool *taller)//變量taller反應(yīng)T長(zhǎng)高與否
{
 if(!*T)
 {
  *T=(BTree)malloc(sizeof(BTNode));
  (*T)->data=e;
  (*T)->lchild=(*T)->rchild=NULL;
  (*T)->BF=EH;
  *taller=true;
 }
 else
 {
  if(e==(*T)->data)//不插入
  {
   *taller=false;
   return false;
  }
  if(e<(*T)->data)
  {
   if(!InsertAVL(&(*T)->lchild,e,taller))//未插入
    return false;
   if(*taller)//以插入左子樹,且左子樹變高
   {
    switch((*T)->BF)
    {
     case LH://原本左子樹比右子樹高,需要做左平衡處理
      LeftBalance(T);
      *taller=false;
      break;
     case EH://原本左右子樹等高,現(xiàn)因左子樹增高而樹增高
      (*T)->BF=LH;
      *taller=true;
      break;
     case RH://原本右子樹比左子樹高,現(xiàn)在左右子樹等高
      (*T)->BF=EH;
      *taller=false;
      break;
    }
   }
  }
  else
  {
   //應(yīng)在T的右子樹中搜尋
   if(!InsertAVL(&(*T)->rchild,e,taller))
    return false;
   if(*taller)//插入右子樹,且右子樹長(zhǎng)高
   {
    switch((*T)->BF)
    {
     case LH://原本左子樹比右子樹高,現(xiàn)在左右子樹等高
      (*T)->BF=EH;
      *taller=false;
      break;
     case EH://原本左右子樹等高,現(xiàn)在右子樹變高
      (*T)->BF=RH;
      *taller=true;
      break;
     case RH://原本右子樹比左子樹高,現(xiàn)在需做右平衡處理
      RightBalance(T);
      *taller=false;
      break;
    }
   }
  }
 }
 return true;
}

bool Find(BTree T,int key)
{
 if(!T)
  return false;
 else if(T->data==key)
  return true;
 else if(T->data<key)
  return Find(T->rchild,key);
 else
  return Find(T->lchild,key);
}

void Output(BTree T)
{
 if(T)
 {
  printf("%d",T->data);
  if(T->lchild||T->rchild)
  {
   printf("(");
   Output(T->lchild);
   printf(",");
   Output(T->rchild);
   printf(")");
  }
 }
}

int main(int argc,char *argv[])
{
 int i;
 int A[]={3,2,1,4,5,6,7,10,9,8};
 BTree T=NULL;
 bool taller;
 for(i=0;i<sizeof(A)/sizeof(int);i++)
  InsertAVL(&T,A[i],&taller);
 Output(T);
 printf("\n");
 if(Find(T,6))
  printf("6 is find in the AVL tree!\n");
 else
  printf("6 is not find in the AVL tree!\n");

 return 0;
}

相關(guān)文章

  • QT實(shí)現(xiàn)按鈕開關(guān)Form窗體的效果的示例代碼

    QT實(shí)現(xiàn)按鈕開關(guān)Form窗體的效果的示例代碼

    本文主要介紹了QT實(shí)現(xiàn)按鈕開關(guān)Form窗體的效果的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • c語(yǔ)言實(shí)現(xiàn)基數(shù)排序解析及代碼示例

    c語(yǔ)言實(shí)現(xiàn)基數(shù)排序解析及代碼示例

    這篇文章主要介紹了c語(yǔ)言實(shí)現(xiàn)基數(shù)排序解析及代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • C++ 通過(guò)指針實(shí)現(xiàn)多態(tài)實(shí)例詳解

    C++ 通過(guò)指針實(shí)現(xiàn)多態(tài)實(shí)例詳解

    這篇文章主要介紹了 C++ 通過(guò)指針實(shí)現(xiàn)多態(tài)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • C語(yǔ)言內(nèi)存的動(dòng)態(tài)分配比較malloc和realloc的區(qū)別

    C語(yǔ)言內(nèi)存的動(dòng)態(tài)分配比較malloc和realloc的區(qū)別

    這篇文章主要介紹了C語(yǔ)言內(nèi)存的動(dòng)態(tài)分配比較malloc和realloc的區(qū)別,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是本文的詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • Linux頁(yè)面置換算法的C語(yǔ)言實(shí)現(xiàn)

    Linux頁(yè)面置換算法的C語(yǔ)言實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了Linux頁(yè)面置換算法的C語(yǔ)言實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C++動(dòng)態(tài)加載so/dll庫(kù)的實(shí)現(xiàn)

    C++動(dòng)態(tài)加載so/dll庫(kù)的實(shí)現(xiàn)

    本文主要介紹了C++動(dòng)態(tài)加載so/dll庫(kù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • C++之std命名空間

    C++之std命名空間

    這篇文章主要介紹了C++之std命名空間使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++ Template應(yīng)用詳解

    C++ Template應(yīng)用詳解

    本篇文章主要介紹了C++ Template應(yīng)用詳解,模板(Template)指C++程序設(shè)計(jì)設(shè)計(jì)語(yǔ)言中采用類型作為參數(shù)的程序設(shè)計(jì),支持通用程序設(shè)計(jì)。
    2016-12-12
  • 基于C++自動(dòng)化編譯工具的使用詳解

    基于C++自動(dòng)化編譯工具的使用詳解

    本篇文章是對(duì)C++中自動(dòng)化編譯工具的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++實(shí)現(xiàn)將s16le的音頻流轉(zhuǎn)換為float類型

    C++實(shí)現(xiàn)將s16le的音頻流轉(zhuǎn)換為float類型

    這篇文章主要為大家詳細(xì)介紹了如何利用C++實(shí)現(xiàn)將s16le的音頻流轉(zhuǎn)換為float類型,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2023-04-04

最新評(píng)論