亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

平衡二叉樹的實現實例

2020-01-26 15:37:06
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

/*
首先平衡二叉樹是一個二叉排序樹;
其基本思想是:
在構建二叉排序樹的過程中,當每插入一個節點時,
先檢查是否因為插入而破壞了樹的平衡性,若是,
找出最小不平衡樹,進行適應的旋轉,使之成為新的平衡二叉樹。
*/
#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為根節點的二叉排序樹進行右旋轉
{
 BTree L;
 L=(*p)->lchild;
 (*p)->lchild=L->rchild;
 L->rchild=(*p);
 *p=L;//p指向新的根節點
}

void L_Rotate(BTree *p)//以p為根節點的二叉排序樹進行左旋轉
{
 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的左子樹平衡度,并作相應的平衡處理
  case LH://新節點插入在T的左孩子的左子樹上,做單右旋處理
   (*T)->BF=L->BF=EH;
   R_Rotate(T);
   break;
  case RH://新插入節點在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://新節點插在T的右孩子的右子樹上,要做單左旋處理
   (*T)->BF=R->BF=EH;
   L_Rotate(T);
   break;
  case LH://新節點插在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反應T長高與否
{
 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://原本左右子樹等高,現因左子樹增高而樹增高
      (*T)->BF=LH;
      *taller=true;
      break;
     case RH://原本右子樹比左子樹高,現在左右子樹等高
      (*T)->BF=EH;
      *taller=false;
      break;
    }
   }
  }
  else
  {
   //應在T的右子樹中搜尋
   if(!InsertAVL(&(*T)->rchild,e,taller))
    return false;
   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 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;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产视频一区二区| 国产精品福利网| 97超碰国产精品女人人人爽| 久色乳综合思思在线视频| 91青草视频久久| 亚洲欧美制服中文字幕| 欧美极品美女电影一区| 欧美激情在线狂野欧美精品| 欧美日韩在线视频观看| 97精品一区二区三区| 亚洲欧美中文日韩v在线观看| 亚洲综合国产精品| 91麻豆国产语对白在线观看| 8050国产精品久久久久久| 成人免费大片黄在线播放| 538国产精品一区二区免费视频| 中文字幕亚洲欧美日韩高清| 亚洲高清av在线| 欧美视频在线免费看| 久久综合五月天| 91精品久久久久久久久久久| 亚洲女成人图区| 国产视频亚洲视频| 不卡伊人av在线播放| 中国人与牲禽动交精品| 97精品国产aⅴ7777| 国产亚洲精品久久| 色狠狠久久aa北条麻妃| 亚洲欧美日韩视频一区| 亚洲国产成人精品久久久国产成人一区| 亚洲偷欧美偷国内偷| 欧美壮男野外gaytube| 国产精品揄拍一区二区| 欧美在线亚洲在线| 国内精品久久影院| 一区二区亚洲欧洲国产日韩| 大胆人体色综合| 欧美韩日一区二区| 欧美又大粗又爽又黄大片视频| 亚洲午夜精品久久久久久久久久久久| 久久中文字幕在线| 欧美成年人在线观看| 欧美激情一区二区三区久久久| 北条麻妃一区二区在线观看| 在线成人激情黄色| 91久久国产精品91久久性色| 午夜精品久久久久久久久久久久| 欧美日韩另类在线| 欧美日韩国产区| 亚洲图片制服诱惑| 久久久久亚洲精品国产| 国产日韩精品在线播放| 91精品国产91久久| 亚洲一区国产精品| 国产精品99免视看9| 日本欧美精品在线| 国产精品最新在线观看| 日韩高清免费观看| 91精品国产沙发| 在线播放国产一区中文字幕剧情欧美| 亚洲热线99精品视频| 欧美丰满老妇厨房牲生活| 国内自拍欧美激情| 欧美日韩综合视频| 久久精品国产清自在天天线| 久久精品视频在线| 国产精品久久色| 17婷婷久久www| 亚洲天堂免费观看| 2021久久精品国产99国产精品| 日韩欧美一区二区三区| 国产精品入口免费视频一| 欧美成人午夜剧场免费观看| 亚洲人永久免费| 久久手机精品视频| 欧美日韩国产中文字幕| 在线播放精品一区二区三区| 国产精品老牛影院在线观看| 国产精品第一视频| 日韩精品久久久久| 亚洲欧美日韩在线高清直播| 久久精品国产电影| 美女扒开尿口让男人操亚洲视频网站| 久久91亚洲人成电影网站| 亚洲剧情一区二区| 欧美精品日韩www.p站| 亚洲xxxx18| 日本不卡免费高清视频| 久久久久久久亚洲精品| 一区二区三区四区精品| 国产精品黄色av| 欧美一级淫片videoshd| 播播国产欧美激情| 欧美性色xo影院| 欧美电影在线观看完整版| 欧美一区二区三区免费视| 欧美性在线观看| 欧美成人国产va精品日本一级| 午夜精品国产精品大乳美女| 国产区精品视频| 国产成人精品综合| 久久免费视频网站| 亚洲精品wwww| 久久精品美女视频网站| 色播久久人人爽人人爽人人片视av| 久久不射热爱视频精品| 国产在线日韩在线| 欧美成人国产va精品日本一级| 国产精品久久999| 日韩在线观看成人| 中文字幕欧美日韩在线| 欧美日韩成人在线视频| 欧美影院在线播放| 26uuu另类亚洲欧美日本老年| 国产97在线观看| 亚洲欧美综合图区| 2019av中文字幕| 欧美极品少妇全裸体| 欧美精品18videos性欧| 日韩中文在线视频| 日韩h在线观看| 国产精品丝袜久久久久久高清| 欧美韩国理论所午夜片917电影| 国产成人拍精品视频午夜网站| 国产精品久久久久久久7电影| 日韩欧美精品网站| 成人免费视频网| 日韩av在线免费播放| 欧美色播在线播放| 欧美激情aaaa| 国产成人亚洲综合91| 久久久久久午夜| 亚洲xxxx在线| 欧美激情精品久久久久久变态| 久久久久久久97| 欧美—级高清免费播放| 97**国产露脸精品国产| 美女少妇精品视频| 久久久久久网址| 国产精品欧美风情| 久久艹在线视频| 国产婷婷成人久久av免费高清| 亚洲天堂第二页| 欧美在线www| 亚洲欧美国产一本综合首页| 亚洲欧美综合另类中字| 日韩美女在线看| 亚洲精品久久久久国产| 欧美亚洲免费电影| 亚洲一区二区三区毛片| 久久视频免费在线播放| 亚洲黄在线观看| 欧美洲成人男女午夜视频| 日韩欧美国产成人| 一本大道香蕉久在线播放29| 欧美中文字幕在线播放| 97视频国产在线| 国产在线观看91精品一区| 国产综合久久久久久| 红桃视频成人在线观看| 91在线中文字幕| 亚洲电影中文字幕| 成人a在线视频| 国产精品视频免费在线观看|