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

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

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

?? 數據結構經典算法的c語言實現
?? 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一区二区三区免费野_久草精品视频
欧美精品一区二区三区在线| 日韩免费观看高清完整版| 韩国视频一区二区| 青青草国产精品亚洲专区无| 日日摸夜夜添夜夜添亚洲女人| 一区二区三区不卡在线观看 | 久久久五月婷婷| 欧美刺激脚交jootjob| 欧美v日韩v国产v| xnxx国产精品| 亚洲国产高清在线观看视频| 国产精品久久久久久久久果冻传媒| 欧美国产日韩a欧美在线观看| 国产精品不卡一区二区三区| 亚洲黄色在线视频| 午夜亚洲福利老司机| 美腿丝袜在线亚洲一区 | 国产精品资源在线观看| av资源站一区| 欧美电影影音先锋| 精品久久一区二区| 亚洲图片另类小说| 丝袜美腿亚洲综合| 成人免费视频app| 欧美日本一道本在线视频| 久久久久青草大香线综合精品| 国产精品伦一区| 天天操天天色综合| 成人动漫一区二区| 在线成人免费观看| 中文字幕一区二区三区蜜月| 亚洲主播在线播放| 国产福利一区二区三区视频| 在线观看视频一区二区| 精品入口麻豆88视频| 亚洲欧美日韩中文播放 | 欧美日本韩国一区| 日本一区免费视频| 三级欧美在线一区| youjizz国产精品| 日韩欧美在线网站| 亚洲男帅同性gay1069| 另类欧美日韩国产在线| 色久优优欧美色久优优| 国产午夜精品久久久久久免费视| 亚洲主播在线播放| youjizz久久| 国产网站一区二区| 久久99精品久久久久| 欧美亚洲高清一区| 亚洲人成亚洲人成在线观看图片| 精品无码三级在线观看视频| 欧美在线free| 亚洲人成电影网站色mp4| 韩国视频一区二区| 精品日韩在线观看| 久久狠狠亚洲综合| 91精选在线观看| 亚洲va欧美va人人爽| 91色.com| 国产精品久久毛片av大全日韩| 国产自产2019最新不卡| 日韩一区二区视频| 日韩精品一卡二卡三卡四卡无卡| 欧美性极品少妇| 一区二区三区四区高清精品免费观看 | 久久久久久黄色| 午夜电影网一区| 欧美中文字幕一区| 亚洲一区二区三区四区在线免费观看| 国产成人在线视频网址| 欧美一卡二卡在线| 久久疯狂做爰流白浆xx| 欧美一区二区成人| 久久国产生活片100| 8x8x8国产精品| 日韩精品亚洲一区| 欧美一区二区三区免费视频| 奇米影视在线99精品| 日韩精品一区二区在线| 久久精品国产第一区二区三区| 精品三级av在线| 国产精品18久久久久久久久| 国产香蕉久久精品综合网| 成人国产在线观看| 亚洲精选免费视频| 欧美日韩另类一区| 麻豆国产一区二区| 国产日韩欧美综合一区| 成人app网站| 亚洲狠狠爱一区二区三区| 欧美一区二区三区在线电影| 国产一区91精品张津瑜| 国产精品九色蝌蚪自拍| 欧美日韩激情在线| 久久99热这里只有精品| 国产蜜臀97一区二区三区| 色老头久久综合| 理论片日本一区| 亚洲女与黑人做爰| 精品乱码亚洲一区二区不卡| 成人av在线一区二区| 亚洲国产精品麻豆| 国产欧美日韩另类视频免费观看| 日本韩国精品在线| 国产一区二区三区国产| 亚洲乱码国产乱码精品精可以看 | 久久免费偷拍视频| 91久久精品午夜一区二区| 蜜臂av日日欢夜夜爽一区| 国产婷婷色一区二区三区| 欧美在线制服丝袜| 国产精品一二三区在线| 香蕉影视欧美成人| 中文字幕一区二区三区四区| 欧美一区二区在线免费观看| 972aa.com艺术欧美| 韩国av一区二区三区在线观看| 亚洲狠狠丁香婷婷综合久久久| 2023国产精品| 69堂成人精品免费视频| 色播五月激情综合网| 国产91对白在线观看九色| 五月婷婷久久综合| 一区二区三区在线影院| 国产欧美精品日韩区二区麻豆天美| 3751色影院一区二区三区| 在线免费视频一区二区| 国产成人精品亚洲午夜麻豆| 日本怡春院一区二区| 亚洲高清在线精品| 亚洲免费观看高清完整版在线观看 | 国产福利不卡视频| 日本免费在线视频不卡一不卡二 | 欧美日韩你懂的| 91日韩在线专区| 99久久久久免费精品国产| 国产一区二区在线看| 免费成人深夜小野草| 亚洲大片免费看| 亚洲乱码中文字幕| 亚洲天堂av老司机| 国产精品女人毛片| 国产欧美精品区一区二区三区| 久久综合久久99| 精品国产91洋老外米糕| 日韩视频免费直播| 日韩欧美亚洲另类制服综合在线| 欧美精品xxxxbbbb| 欧美一区二区三区四区高清| 欧美精品丝袜中出| 制服丝袜av成人在线看| 欧美人与z0zoxxxx视频| 日韩一区二区三区三四区视频在线观看| 欧美精品 日韩| 欧美一二三区在线| 久久综合色天天久久综合图片| 欧美videossexotv100| 精品国产免费人成在线观看| 精品99一区二区| 中文一区一区三区高中清不卡| 欧美国产精品一区二区| 亚洲丝袜制服诱惑| 婷婷成人激情在线网| 久久99精品视频| 国产二区国产一区在线观看| 成人成人成人在线视频| 日本韩国欧美在线| 欧美一级一区二区| 国产欧美日韩另类一区| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲一区二区三区四区在线免费观看| 亚洲成av人影院在线观看网| 免费看黄色91| 丁香婷婷综合网| 欧美日本国产一区| 久久久影院官网| 一区二区三区毛片| 激情综合网最新| 色诱视频网站一区| 日韩一本二本av| 亚洲欧美日韩国产综合| 欧美a一区二区| 91亚洲男人天堂| 日韩亚洲欧美综合| 亚洲同性gay激情无套| 麻豆国产欧美一区二区三区| 97久久超碰精品国产| 欧美高清一级片在线| 国产精品网站导航| 免费人成网站在线观看欧美高清| 不卡视频一二三| 欧美成人福利视频| 亚洲一区精品在线| 成人黄色综合网站| 精品欧美乱码久久久久久1区2区 | 欧美va日韩va| 一区二区三区精品视频| 高清视频一区二区| 日韩一级欧美一级|