亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 平衡二叉排序樹的綜合操作.cpp

?? 介紹了算法基礎
?? CPP
字號:
//* * * * * * * * * * * * * * * * * * * * * * * *
//*CHAPTER          :6  (6_5)                   *
//*PROGRAM          :平衡二叉排序樹的綜合操作   *
//*CONTENT          :Insert,Search              *
//* * * * * * * * * * * * * * * * * * * * * * * *
#include <dos.h>
#include <conio.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#define LH 1   //左子樹高
#define EH 0   //左右子樹等高
#define RH -1  //右子樹高
enum BOOL{False,True};
typedef struct //定義記錄的結構
{int keynum;   //在本程序中只含有關鍵字一項
}Record;
typedef struct  BSTNode   //定義平衡二叉樹節點結構
{Record  data;		  //數據域
 int bf;                  //平衡因子
 struct BSTNode *lchild,*rchild; //左右孩子指針域
}BSTNode,*BSTree;
BSTree SearchBST(BSTree,int); //在平衡二叉排序樹中查找元素
BOOL InsertAVL(BSTree &,Record,BOOL&);  //在平衡二叉排序樹中插入元素
void LeftBalance(BSTree &);    //左平衡旋轉處理
void RightBalance(BSTree &);   //右平衡旋轉處理
void InorderBST(BSTree); //中序遍歷二叉排序樹,即從小到大顯示各元素
void R_Rotate(BSTree &); //右旋處理
void L_Rotate(BSTree &); //左旋處理
void main()
{BSTree T,p;
 Record R;
 char ch,keyword,j='y';
 BOOL temp,taller;
 textbackground(3);  //設定屏幕顏色
 textcolor(15);
 clrscr();
 //-------------------------程序說明-------------------------------
 printf("This program will show how to operate to \na Balanced Binary Sort  Tree.\n");
 printf("You can display all elems,search a elem,insert a elem.\n");
 //----------------------------------------------------------------
 T=NULL;
 while(j!='n')
    {printf("1.display\n");
     printf("2.search\n");
     printf("3.insert\n");
     printf("4.exit\n");
     scanf(" %c",&ch); //輸入操作選項
     switch(ch)
      {case '1':if(!T) printf("The BST has no elem.\n"); //此時平衡二叉排序樹空
		else {InorderBST(T);printf("\n");} //中序遍歷二叉樹,即從小到大顯示所有元素
		break;
       case '2':printf("Input the keynumber of elem to be searched(int number):");
		scanf("%d",&R.keynum); //輸入要查找元素的關鍵字
		p=SearchBST(T,R.keynum);
                  //p=NULL:查找不成功;p!=NULL:查找成功,p指向該記錄
		if(!p) printf("The record isn't existed!\n"); //沒有找到
		else printf("The record has been found!\n"); //成功找到
		break;
       case '3':printf("Input the record to be inserted(int number):");
		scanf("%d",&R.keynum); //輸入要插入元素的關鍵字
		temp=InsertAVL(T,R,taller);
	         //temp=True:成功插入該記錄;temp=False:樹中已有與記錄R有相同關鍵字的記錄
                if(!temp) printf("The record has been existed!\n"); //該元素已經存在
		else printf("Sucess to insert!\n"); //成功插入
		break;
       default: j='n';
    }
 }
 printf("The program is over!\nPress any key to shut off the window!\n");
 getchar();getchar();
}
void InorderBST(BSTree T)
{//以中序方式遍歷二叉排序樹T,即從小到大顯示二叉排序樹的所有元素
 if(T->lchild) InorderBST(T->lchild);
 printf("%-4d",T->data.keynum);
 if(T->rchild) InorderBST(T->rchild);
}

BSTree SearchBST(BSTree T,int key)
{//在根指針T所指二叉排序樹中遞歸的查找其關鍵字等于key的元素,若查找成功
 //則返回該元素的地址,若查找不成功,返回地址為NULL
 if((!T)||key==T->data.keynum) return (T);
 else if(key<T->data.keynum) return(SearchBST(T->lchild,key));
 else return(SearchBST(T->rchild,key));
}

BOOL InsertAVL(BSTree &T,Record e,BOOL &taller)
{//若在平衡二叉排序樹T中中不存在和e有相同關鍵字的結點,則插入一個數據元素
 //為e的新結點,并返回True,否則返回False。若因插入而使平衡二叉排序樹失去
 //平衡,則做平衡旋轉處理,布爾變量taller反映T長高與否
 if(!T)      //插入新結點,樹“長高”,置taller為True
   {T=(BSTree)malloc(sizeof(BSTNode));
    T->data=e;
    T->lchild=T->rchild=NULL;
    T->bf=EH;
    taller=True;
   }
 else  
    {if(e.keynum==T->data.keynum)  //樹中已有與e有相同關鍵字的結點
	{taller=False; return False;} //不再插入
     if(e.keynum<T->data.keynum)   //應繼續在*T的左子樹中進行搜索
	{if(!InsertAVL(T->lchild,e,taller)) return False; //未插入
	 if(taller)         //已插入到*T的左子樹中且左子樹“長高”
	   switch(T->bf)    //檢查*T的平衡度
	     {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)         //已插入到*T的右子樹中且右子樹“長高”
	   switch(T->bf)    //檢查*T的平衡度
	     {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;
}
void LeftBalance(BSTree &T)
{//對以指針T所指結點為根的二叉樹做左平衡旋轉處理,本算法結束時,
 //指針T指向新的根結點
 BSTree lc,rd;
 lc=T->lchild;  //lc指向*T的左子樹根結點
 switch(lc->bf) //檢查*T的左子樹的平衡度,并作相應平衡處理 
    {case LH:T->bf=lc->bf=EH; //新結點插入在*T的左孩子的左子樹上,要作單右旋處理
	     R_Rotate(T);
	     break;
     case RH:               //新結點插入在*T的左孩子的右子樹上,要作雙旋處理
             rd=lc->rchild; //rd指向*T的左孩子的右子樹根
	     switch(rd->bf) //修改*T及其左孩子的平衡因子 
		{case LH:T->bf=RH;lc->bf=EH;break;
		 case EH:T->bf=lc->bf=EH;break;
		 case RH:T->bf=EH;lc->bf=LH;break;
		}
	     rd->bf=EH;
	     L_Rotate(T->lchild); //對*T的左子樹作左旋平衡處理

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费看黄yyy456| 7777精品伊人久久久大香线蕉经典版下载 | 国产一本一道久久香蕉| 美女精品一区二区| 91久久一区二区| 亚洲人妖av一区二区| 福利91精品一区二区三区| 精品日韩在线观看| 在线欧美一区二区| 国产精品人妖ts系列视频| 国产精品综合一区二区三区| 欧美大黄免费观看| 久久精品久久99精品久久| 日韩欧美区一区二| 国精产品一区一区三区mba视频| 日韩一级片网站| 日本欧美大码aⅴ在线播放| 日韩写真欧美这视频| 激情丁香综合五月| 国产精品欧美极品| 91丨porny丨在线| 青青草成人在线观看| 精品国产一区久久| 一本色道久久加勒比精品| 亚洲丶国产丶欧美一区二区三区| 欧美日韩美少妇| 国产中文字幕一区| 亚洲欧美色综合| 精品欧美一区二区三区精品久久| 国产凹凸在线观看一区二区| 亚洲蜜臀av乱码久久精品蜜桃| 国产精品久久久久久久久免费相片| 日韩毛片在线免费观看| 欧美浪妇xxxx高跟鞋交| 精品少妇一区二区| 色综合久久久久网| 免费观看久久久4p| 亚洲色图视频网站| 久久久精品天堂| 欧美日韩国产不卡| 99久久99久久精品国产片果冻| 日本欧美一区二区| 亚洲高清免费视频| 自拍偷自拍亚洲精品播放| 欧美成人video| 欧美美女喷水视频| 欧洲精品在线观看| 国产成人一级电影| 精品在线视频一区| 蜜桃视频一区二区三区在线观看| 国产精品短视频| 国产亚洲一区二区三区在线观看| 欧美色倩网站大全免费| 91久久一区二区| 欧美做爰猛烈大尺度电影无法无天| 99精品视频一区二区| 97国产一区二区| 成人av综合在线| 9色porny自拍视频一区二区| 欧美日韩成人在线| 4438x亚洲最大成人网| 日韩一区二区三区免费观看| 欧美va亚洲va在线观看蝴蝶网| 日韩一区二区精品在线观看| 日韩欧美专区在线| 欧美日韩电影一区| 欧美成人激情免费网| 国产人久久人人人人爽| 一区二区三区日韩在线观看| 日本vs亚洲vs韩国一区三区| 国产一区二区三区高清播放| 成人免费看黄yyy456| 欧美亚洲高清一区| 国产三级精品在线| 一二三区精品福利视频| 久久超级碰视频| 99这里只有久久精品视频| 91精品国产综合久久精品app| 欧美第一区第二区| 亚洲午夜日本在线观看| 久久国产成人午夜av影院| 色婷婷av一区二区三区gif| 欧美日韩精品一区二区三区蜜桃 | 日韩一区二区三免费高清| 精品女同一区二区| 夜夜嗨av一区二区三区四季av| 精品午夜一区二区三区在线观看| av成人老司机| 国产日韩欧美精品综合| 久久国产福利国产秒拍| 欧美日韩精品三区| 亚洲精品自拍动漫在线| 国产91丝袜在线播放0| 欧美一区二区在线免费观看| 一区二区三区在线视频观看58| 国产成人在线视频网站| 精品理论电影在线观看| 天堂va蜜桃一区二区三区| 91蜜桃传媒精品久久久一区二区| 久久久久久97三级| 国产精品一区二区视频| 精品成人在线观看| 精品制服美女久久| 久久精品人人做人人爽97| 六月丁香婷婷色狠狠久久| 日韩精品自拍偷拍| 国产一区二区精品久久91| xfplay精品久久| 国产制服丝袜一区| 国产精品福利av| 欧美怡红院视频| 亚洲成人三级小说| 日韩女同互慰一区二区| 精品一区二区三区的国产在线播放| 欧美一区二区三区免费在线看| 免费在线一区观看| 国产亚洲短视频| 色视频欧美一区二区三区| 亚洲成a人在线观看| 精品久久国产字幕高潮| 成人午夜看片网址| 亚洲第一二三四区| 欧美精品一区二区高清在线观看| 国产精品性做久久久久久| 一区二区三区成人在线视频| 日韩亚洲欧美高清| 在线观看亚洲a| 麻豆国产91在线播放| 亚洲乱码国产乱码精品精98午夜 | 亚洲日本欧美天堂| 日韩一级片网站| 日本久久一区二区| 经典三级一区二区| 亚洲激情校园春色| 中文字幕一区在线| 日韩欧美综合在线| 色综合久久中文字幕| 国产乱码精品一区二区三区av| 亚洲免费观看高清完整| 欧美精品1区2区| 国产精品69久久久久水密桃| 亚洲一区二区三区中文字幕 | 97精品电影院| 韩国v欧美v日本v亚洲v| 天堂久久久久va久久久久| 国产精品久久久久一区二区三区共| 制服丝袜日韩国产| 91成人在线精品| 在线精品视频免费观看| av在线不卡免费看| 成人在线视频首页| 国产乱码精品一区二区三区av| 奇米四色…亚洲| 日韩福利视频导航| 蜜臀91精品一区二区三区| 日韩电影网1区2区| 精品一区二区影视| 久久99日本精品| 成人一区在线看| 国产mv日韩mv欧美| 91在线观看污| 欧美日韩三级视频| 日韩亚洲欧美高清| 欧美极品少妇xxxxⅹ高跟鞋| 国产精品电影一区二区| 亚洲乱码中文字幕综合| 亚洲一级二级三级在线免费观看| 亚洲高清久久久| 国产一区久久久| 色又黄又爽网站www久久| 在线播放亚洲一区| 国产亚洲精久久久久久| 悠悠色在线精品| 黑人巨大精品欧美一区| av综合在线播放| 日韩欧美一级特黄在线播放| 国产亚洲综合色| 丝袜美腿高跟呻吟高潮一区| 九九精品视频在线看| 972aa.com艺术欧美| 日韩午夜激情免费电影| 亚洲欧洲精品天堂一级| 免费观看久久久4p| 99精品国产热久久91蜜凸| 日韩精品专区在线影院观看| 亚洲人成人一区二区在线观看| 久久不见久久见中文字幕免费| 91亚洲国产成人精品一区二三 | 久久精品国产**网站演员| 亚洲欧美日韩综合aⅴ视频| 亚洲乱码中文字幕| 国产精品18久久久久久久久久久久 | 国产乱理伦片在线观看夜一区| 91国偷自产一区二区开放时间 | 国产亚洲欧美日韩在线一区| 午夜激情一区二区三区| 欧洲另类一二三四区| 日韩美女视频19| 色悠久久久久综合欧美99| 亚洲天堂免费看|