




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示.v.平衡二叉樹(shù)操作的演示需求分析本程序是利用平衡二叉樹(shù),實(shí)現(xiàn)動(dòng)態(tài)查找表的根本功能:創(chuàng)立表,查找、插入、刪除。具體功能:初始,平衡二叉樹(shù)為空樹(shù),操作界面給出創(chuàng)立、查找、插入、刪除、合并、分裂六種操作供選擇。每種操作均提示輸入關(guān)鍵字。每次插入或刪除一個(gè)結(jié)點(diǎn)后,更新平衡二叉樹(shù)的顯示。平衡二叉樹(shù)的顯示采用凹入表現(xiàn)形式。合并兩棵平衡二叉樹(shù)。把一棵二叉樹(shù)分裂為兩棵平衡二叉樹(shù),使得在一棵樹(shù)中的所有關(guān)鍵字都小于或等于x,另一棵樹(shù)中的任一關(guān)鍵字都大于x。如以下圖:2.概要設(shè)計(jì)平衡二叉樹(shù)是在構(gòu)造二叉排序樹(shù)的過(guò)程中,每當(dāng)插入一個(gè)新結(jié)點(diǎn)時(shí),首先檢查是否因插入新結(jié)點(diǎn)而破壞了二叉排序樹(shù)的平衡性,假設(shè)是那么找出其中的最小不平衡子樹(shù),在保持二叉排序樹(shù)特性的前提下,調(diào)整最小不平衡子樹(shù)中各結(jié)點(diǎn)之間的關(guān)系,進(jìn)展相應(yīng)的旋轉(zhuǎn),使之成為新的平衡子樹(shù)。具體步驟:每當(dāng)插入一個(gè)新結(jié)點(diǎn),從該結(jié)點(diǎn)開(kāi)場(chǎng)向上計(jì)算各結(jié)點(diǎn)的平衡因子,即計(jì)算該結(jié)點(diǎn)的祖先結(jié)點(diǎn)的平衡因子,假設(shè)該結(jié)點(diǎn)的祖先結(jié)點(diǎn)的平衡因子的絕對(duì)值不超過(guò)1,那么平衡二叉樹(shù)沒(méi)有失去平衡,繼續(xù)插入結(jié)點(diǎn);假設(shè)插入結(jié)點(diǎn)的某祖先結(jié)點(diǎn)的平衡因子的絕對(duì)值大于1,那么找出其中最小不平衡子樹(shù)的根結(jié)點(diǎn);判斷新插入的結(jié)點(diǎn)與最小不平衡子樹(shù)的根結(jié)點(diǎn)個(gè)關(guān)系,確定是那種類(lèi)型的調(diào)整;如果是LL型或RR型,只需應(yīng)用扁擔(dān)原理旋轉(zhuǎn)一次,在旋轉(zhuǎn)過(guò)程中,如果出現(xiàn)沖突,應(yīng)用旋轉(zhuǎn)優(yōu)先原那么調(diào)整沖突;如果是LR型或RL型,那么需應(yīng)用扁擔(dān)原理旋轉(zhuǎn)兩次,第一次最小不平衡子樹(shù)的根結(jié)點(diǎn)先不動(dòng),調(diào)整插入結(jié)點(diǎn)所在子樹(shù),第二次再調(diào)整最小不平衡子樹(shù),在旋轉(zhuǎn)過(guò)程中,如果出現(xiàn)沖突,應(yīng)用旋轉(zhuǎn)優(yōu)先原那么調(diào)整沖突;數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第1頁(yè)。計(jì)算調(diào)整后的平衡二叉樹(shù)中各結(jié)點(diǎn)的平衡因子,檢驗(yàn)是否因?yàn)樾D(zhuǎn)而破壞其他結(jié)點(diǎn)的平衡因子,以及調(diào)整后平衡二叉樹(shù)中是否存在平衡因子大于1的結(jié)點(diǎn)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第1頁(yè)。流程圖詳細(xì)設(shè)計(jì)二叉樹(shù)類(lèi)型定義:typedefintStatus;typedefintElemType;typedefstructBSTNode{ElemTypedata;intbf;structBSTNode*lchild,*rchild;}BSTNode,*BSTree;StatusSearchBST(BSTreeT,ElemTypee)//查找voidR_Rotate(BSTree&p)//右旋voidL_Rotate(BSTree&p)//左旋voidLeftBalance(BSTree&T)//插入平衡調(diào)整voidRightBalance(BSTree&T)//插入平衡調(diào)整StatusInsertAVL(BSTree&T,ElemTypee,int&taller)//插入voidDELeftBalance(BSTree&T)//刪除平衡調(diào)整voidDERightBalance(BSTree&T)//刪除平衡調(diào)整StatusDelete(BSTree&T,int&shorter)//刪除操作StatusDeleteAVL(BSTree&T,ElemTypee,int&shorter)//刪除操作voidmerge(BSTree&T1,BSTree&T2)//合并操作數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第2頁(yè)。voidsplitBSTree(BSTreeT,ElemTypee,BSTree&T1,BSTree&T2)//數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第2頁(yè)。voidPrintBSTree(BSTree&T,intlev)//凹入表顯示附錄源代碼:*include<stdio.h>*include<stdlib.h>//*defineTRUE1//*defineFALSE0//*defineOK1//*defineERROR0*defineLH+1*defineEH0*defineRH-1//二叉類(lèi)型樹(shù)的類(lèi)型定義typedefintStatus;typedefintElemType;typedefstructBSTNode{ElemTypedata;intbf;//結(jié)點(diǎn)的平衡因子structBSTNode*lchild,*rchild;//左、右孩子指針}BSTNode,*BSTree;/*查找算法*/StatusSearchBST(BSTreeT,ElemTypee){if(!T){return0;//查找失敗}elseif(e==T->data){return1;//查找成功}elseif(e<T->data){returnSearchBST(T->lchild,e);}else{returnSearchBST(T->rchild,e);}}//右旋voidR_Rotate(BSTree&p){BSTreelc;//處理之前的左子樹(shù)根結(jié)點(diǎn)數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第3頁(yè)。lc=p->lchild;//lc指向的*p數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第3頁(yè)。p->lchild=lc->rchild;//lc的右子樹(shù)掛接為*P的左子樹(shù)lc->rchild=p;p=lc;//p指向新的根結(jié)點(diǎn)}//左旋voidL_Rotate(BSTree&p){BSTreerc;rc=p->rchild;//rc指向的*p的右子樹(shù)根結(jié)點(diǎn)p->rchild=rc->lchild;//rc的左子樹(shù)掛接為*p的右子樹(shù)rc->lchild=p;p=rc;//p指向新的根結(jié)點(diǎn)}//對(duì)以指針T所指結(jié)點(diǎn)為根結(jié)點(diǎn)的二叉樹(shù)作左平衡旋轉(zhuǎn)處理,//本算法完畢時(shí)指針T指向新的根結(jié)點(diǎn)voidLeftBalance(BSTree&T){BSTreelc,rd;lc=T->lchild;//lc指向*T的左子樹(shù)根結(jié)點(diǎn)switch(lc->bf){//檢查*T的左子樹(shù)的平衡度,并做相應(yīng)的平衡處理caseLH://新結(jié)點(diǎn)插入在*T的左孩子的左子樹(shù),要做單右旋處理T->bf=lc->bf=EH;R_Rotate(T);break;caseRH://新結(jié)點(diǎn)插入在*T的左孩子的右子樹(shù)上,做雙旋處理rd=lc->rchild;//rd指向*T的左孩子的右子樹(shù)根switch(rd->bf){//修改*T及其左孩子的平衡因子caseLH:T->bf=RH;lc->bf=EH;break;caseEH:T->bf=lc->bf=EH;break;caseRH:T->bf=EH;lc->bf=LH;break;}rd->bf=EH;L_Rotate(T->lchild);//對(duì)*T的左子樹(shù)作左旋平衡處理R_Rotate(T);//對(duì)*T作右旋平衡處理}}//右平衡旋轉(zhuǎn)處理voidRightBalance(BSTree&T){BSTreerc,ld;rc=T->rchild;switch(rc->bf){數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第4頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第4頁(yè)。T->bf=rc->bf=EH;L_Rotate(T);break;caseLH:ld=rc->lchild;switch(ld->bf){caseLH:T->bf=RH;rc->bf=EH;break;caseEH:T->bf=rc->bf=EH;break;caseRH:T->bf=EH;rc->bf=LH;break;}ld->bf=EH;R_Rotate(T->rchild);L_Rotate(T);}}//插入結(jié)點(diǎn)StatusInsertAVL(BSTree&T,ElemTypee,int&taller){//taller反響T長(zhǎng)高與否if(!T){//插入新結(jié)點(diǎn),樹(shù)長(zhǎng)高,置taller為trueT=(BSTree)malloc(sizeof(BSTNode));T->data=e;T->lchild=T->rchild=NULL;T->bf=EH;taller=1;}else{if(e==T->data){taller=0;return0;}if(e<T->data){if(!InsertAVL(T->lchild,e,taller))//未插入return0;if(taller)//已插入到*T的左子樹(shù)中且左子樹(shù)長(zhǎng)高switch(T->bf){//檢查*T的平衡度,作相應(yīng)的平衡處理caseLH:LeftBalance(T);taller=0;break;caseEH:T->bf=LH;數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第5頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第5頁(yè)。break;caseRH:T->bf=EH;taller=0;break;}}else{if(!InsertAVL(T->rchild,e,taller)){return0;}if(taller)//插入到*T的右子樹(shù)且右子樹(shù)增高switch(T->bf){//檢查*T的平衡度caseLH:T->bf=EH;taller=0;break;caseEH:T->bf=RH;taller=1;break;caseRH:RightBalance(T);taller=0;break;}}}return1;}voidDELeftBalance(BSTree&T){//刪除平衡調(diào)整BSTreelc,rd;lc=T->lchild;switch(lc->bf){caseLH:T->bf=EH;//lc->bf=EH;R_Rotate(T);break;caseEH:T->bf=EH;lc->bf=EH;R_Rotate(T);數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第6頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第6頁(yè)。caseRH:rd=lc->rchild;switch(rd->bf){caseLH:T->bf=RH;lc->bf=EH;break;caseEH:T->bf=lc->bf=EH;break;caseRH:T->bf=EH;lc->bf=LH;break;}rd->bf=EH;L_Rotate(T->lchild);R_Rotate(T);}}voidDERightBalance(BSTree&T)//刪除平衡調(diào)整{BSTreerc,ld;rc=T->rchild;switch(rc->bf){caseRH:T->bf=EH;//rc->bf=EH;L_Rotate(T);break;caseEH:T->bf=EH;//rc->bf=EH;L_Rotate(T);break;caseLH:ld=rc->lchild;switch(ld->bf){caseLH:T->bf=RH;rc->bf=EH;break;caseEH:T->bf=rc->bf=EH;break;caseRH:T->bf=EH;rc->bf=LH;break;}ld->bf=EH;R_Rotate(T->rchild);L_Rotate(T);數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第7頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第7頁(yè)。}voidSDelete(BSTree&T,BSTree&q,BSTree&s,int&shorter){if(s->rchild){SDelete(T,s,s->rchild,shorter);if(shorter)switch(s->bf){caseEH:s->bf=LH;shorter=0;break;caseRH:s->bf=EH;shorter=1;break;caseLH:DELeftBalance(s);shorter=0;break;}return;}T->data=s->data;if(q!=T)q->rchild=s->lchild;elseq->lchild=s->lchild;shorter=1;}//刪除結(jié)點(diǎn)StatusDelete(BSTree&T,int&shorter){BSTreeq;if(!T->rchild){q=T;T=T->lchild;free(q);shorter=1;}elseif(!T->lchild){q=T;T=T->rchild;free(q);shorter=1;}數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第8頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第8頁(yè)。SDelete(T,T,T->lchild,shorter);if(shorter)switch(T->bf){caseEH:T->bf=RH;shorter=0;break;caseLH:T->bf=EH;shorter=1;break;caseRH:DERightBalance(T);shorter=0;break;}}return1;}StatusDeleteAVL(BSTree&T,ElemTypee,int&shorter){intsign=0;if(!T){returnsign;}else{if(e==T->data){sign=Delete(T,shorter);returnsign;}elseif(e<T->data){sign=DeleteAVL(T->lchild,e,shorter);if(shorter)switch(T->bf){caseEH:T->bf=RH;shorter=0;break;caseLH:T->bf=EH;shorter=1;break;caseRH:DERightBalance(T);數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第9頁(yè)。sh數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第9頁(yè)。break;}returnsign;}else{sign=DeleteAVL(T->rchild,e,shorter);if(shorter)switch(T->bf){caseEH:T->bf=LH;shorter=0;break;caseRH:T->bf=EH;break;caseLH:DELeftBalance(T);shorter=0;break;}returnsign;}}}//合并voidmerge(BSTree&T1,BSTree&T2){inttaller=0;if(!T2)return;merge(T1,T2->lchild);InsertAVL(T1,T2->data,taller);merge(T1,T2->rchild);}//分裂voidsplit(BSTreeT,ElemTypee,BSTree&T1,BSTree&T2){inttaller=0;if(!T)return;split(T->lchild,e,T1,T2);if(T->data>e)InsertAVL(T2,T->data,taller);elseInsertAVL(T1,T->data,taller);數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第10頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第10頁(yè)。}//分裂voidsplitBSTree(BSTreeT,ElemTypee,BSTree&T1,BSTree&T2){BSTreet1=NULL,t2=NULL;split(T,e,t1,t2);T1=t1;T2=t2;return;}//構(gòu)建voidCreatBSTree(BSTree&T){intnum,i,e,taller=0;printf("輸入結(jié)點(diǎn)個(gè)數(shù):");scanf("%d",&num);printf("請(qǐng)順序輸入結(jié)點(diǎn)值\n");for(i=0;i<num;i++){printf("第%d個(gè)結(jié)點(diǎn)的值",i+1);scanf("%d",&e);InsertAVL(T,e,taller);}printf("構(gòu)建成功,輸入任意字符返回\n");getchar();getchar();}//凹入表形式顯示方法voidPrintBSTree(BSTree&T,intlev){inti;if(T->rchild)PrintBSTree(T->rchild,lev+1);for(i=0;i<lev;i++)printf("");printf("%d\n",T->data);if(T->lchild)PrintBSTree(T->lchild,lev+1);}voidStart(BSTree&T1,BSTree&T2){intcho,taller,e,k;taller=0;k=0;while(1){system("cls");printf("平衡二叉樹(shù)操作的演示\n\n");printf("********************************\n");數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第11頁(yè)。printf("平衡二叉樹(shù)顯示區(qū)數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第11頁(yè)。printf("T1樹(shù)\n");if(!T1)printf("\n當(dāng)前為空樹(shù)\n");else{PrintBSTree(T1,1);}printf("T2樹(shù)\n");if(!T2)printf("\n當(dāng)前為空樹(shù)\n");elsePrintBSTree(T2,1);printf("\n******************************************************************************\n");printf("T1操作:1.創(chuàng)立2.插入3.查找4.刪除10.分裂\n");printf("T2操作:5.創(chuàng)立6.插入7.查找8.刪除11.分裂\n");printf("9.合并T1,T20.退出\n");printf("******************************************************************************\n");printf("輸入你要進(jìn)展的操作:");scanf("%d",&cho);switch(cho){case1:CreatBSTree(T1);break;case2:printf("請(qǐng)輸入要插入關(guān)鍵字的值");scanf("%d",&e);InsertAVL(T1,e,taller);break;case3:printf("請(qǐng)輸入要查找關(guān)鍵字的值");scanf("%d",&e);if(SearchBST(T1,e))printf("查找成功!\n");elseprintf("查找失敗!\n");printf("按任意鍵返回87");getchar();getchar();break;case4:printf("請(qǐng)輸入要?jiǎng)h除關(guān)鍵字的值");scanf("%d",&e);if(DeleteAVL(T1,e,k))printf("刪除成功!\n");數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第12頁(yè)。數(shù)據(jù)結(jié)構(gòu)平衡二叉樹(shù)的操作演示全文共14頁(yè),當(dāng)前為第12頁(yè)。printf("刪除失??!\n");printf("按任意鍵返回");g
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- Review 2(教學(xué)設(shè)計(jì))-2023-2024學(xué)年閩教版英語(yǔ)三年級(jí)下冊(cè)
- 實(shí)踐理念落實(shí)在育嬰師考試中的應(yīng)用試題及答案
- 完備的稅務(wù)師考試資料試題及答案
- 2025-2030中國(guó)甲醛行業(yè)市場(chǎng)發(fā)展趨勢(shì)與前景展望戰(zhàn)略研究報(bào)告
- 2025-2030中國(guó)甲基乙烯基醚行業(yè)市場(chǎng)現(xiàn)狀供需分析及投資評(píng)估規(guī)劃分析研究報(bào)告
- 2025-2030中國(guó)生物精煉產(chǎn)品行業(yè)市場(chǎng)現(xiàn)狀供需分析及投資評(píng)估規(guī)劃分析研究報(bào)告
- 2025-2030中國(guó)玻璃加工機(jī)行業(yè)運(yùn)營(yíng)格局及前景營(yíng)銷(xiāo)推廣分析研究報(bào)告
- 2025-2030中國(guó)環(huán)孢素行業(yè)市場(chǎng)發(fā)展分析及發(fā)展趨勢(shì)與投資前景研究報(bào)告
- 環(huán)境衛(wèi)生的重要性研究試題及答案
- 2025-2030中國(guó)焙烤食品糖制品市場(chǎng)消費(fèi)趨勢(shì)調(diào)查與投資效益研究研究報(bào)告
- 小學(xué)生化石科普課件
- 管道溝槽開(kāi)挖施工方案
- 混凝土車(chē)租賃方案
- 環(huán)衛(wèi)工職業(yè)病防治管理制度
- 江蘇鎮(zhèn)江市2025屆高三下學(xué)期一模考試數(shù)學(xué)試題含解析
- 《電信基礎(chǔ)設(shè)施維護(hù)規(guī)程》
- 《城市數(shù)字孿生標(biāo)準(zhǔn)化白皮書(shū)(2022版)》
- 城鄉(xiāng)融合指標(biāo)體系構(gòu)建的四個(gè)維度和四個(gè)向度
- 直流輸電技術(shù)培訓(xùn)課件
- 《工業(yè)園區(qū)物業(yè)服務(wù)》課件
- 原產(chǎn)地證書(shū)【模板】
評(píng)論
0/150
提交評(píng)論