




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、實(shí)驗(yàn)報(bào)告第 7 頁(yè) 共 7 頁(yè)一、實(shí)驗(yàn)?zāi)康?、熟悉二叉樹樹的基本操作。2、掌握二叉樹的實(shí)現(xiàn)以及實(shí)際應(yīng)用。3、加深二叉樹的理解,逐步培養(yǎng)解決實(shí)際問(wèn)題的編程能力。二、實(shí)驗(yàn)環(huán)境1臺(tái)WINDOWS環(huán)境的PC機(jī),裝有Visual C+ 6.0。三、實(shí)驗(yàn)內(nèi)容【問(wèn)題描述】現(xiàn)需要編寫一套二叉樹的操作函數(shù),以便用戶能夠方便的利用這些函數(shù)來(lái)實(shí)現(xiàn)自己的應(yīng)用。其中操作函數(shù)包括:1> 創(chuàng)建二叉樹CreateBTNode(*b,*str):根據(jù)二叉樹括號(hào)表示法的字符串*str生成對(duì)應(yīng)的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。2> 輸出二叉樹DispBTNode(*b):以括號(hào)表示法輸出一棵二叉樹。3> 查找結(jié)點(diǎn)FindNode(
2、*b,x):在二叉樹b中尋找data域值為x的結(jié)點(diǎn),并返回指向該結(jié)點(diǎn)的指針。4> 求高度BTNodeDepth(*b):求二叉樹b的高度。若二叉樹為空,則其高度為0;否則,其高度等于左子樹與右子樹中的最大高度加l。5> 求二叉樹的結(jié)點(diǎn)個(gè)數(shù)NodesCount(BTNode *b)6> 先序遍歷的遞歸算法:void PreOrder(BTNode *b) 7> 中序遍歷的遞歸算法:void InOrder(BTNode *b) 8> 后序遍歷遞歸算法:void PostOrder(BTNode *b) 9> 層次遍歷算法void LevelOrder(BTNo
3、de *b)【基本要求】實(shí)現(xiàn)以上9個(gè)函數(shù)。主函數(shù)中實(shí)現(xiàn)以下功能:創(chuàng)建下圖中的樹b輸出二叉樹b找到H節(jié)點(diǎn),輸出其左右孩子值輸出b的高度輸出b的節(jié)點(diǎn)個(gè)數(shù)輸出b的四種遍歷順序ABDCEHJKLMNFGI上圖轉(zhuǎn)化為二叉樹括號(hào)表示法為A(B(D,E(H(J,K(L,M(,N),C(F,G(,I)程序:#include <stdio.h>#include <malloc.h>#define MaxSize 100typedef char ElemType;typedef struct nodeElemType data;/*數(shù)據(jù)元素*/struct node *lchild;/*指
4、向左孩子*/struct node *rchild;/*指向右孩子*/ BTNode;void CreateBTNode(BTNode *&b,char *str);/創(chuàng)建BTNode *FindNode(BTNode *b,ElemType x);/查找節(jié)點(diǎn)int BTNodeHeight(BTNode *b);/求高度void DispBTNode(BTNode *b);/輸出int NodesCount(BTNode *b);/二叉樹的結(jié)點(diǎn)個(gè)數(shù)void PreOrder(BTNode *b);/先序遍歷遞歸void InOrder(BTNode *b);/中序遍歷遞歸void P
5、ostOrder(BTNode *b);/后序遍歷遞歸void LevelOrder(BTNode *b);/層次遍歷/創(chuàng)建void CreateBTNode(BTNode *&b,char *str)BTNode *StMaxSize,*p=NULL;int top=-1,k,j=0;char ch;b=NULL;ch=strj;while(ch!='0')switch(ch)case '(':top+;Sttop=p;k=1;break;case ')':top-;break;case ',':k=2;break;de
6、fault:p=(BTNode *)malloc(sizeof(BTNode);p->data=ch;p->lchild=p->rchild=NULL;if(b=NULL)b=p;elseswitch(k)case 1:Sttop->lchild=p;break;case 2:Sttop->rchild=p;break;j+;ch=strj;/輸出void DispBTNode(BTNode *b)if(b!=NULL)printf("%c",b->data);if(b->lchild!=NULL|b->rchild!=NUL
7、L)printf("(");DispBTNode(b->lchild);if(b->rchild!=NULL)printf(",");DispBTNode(b->rchild);printf(")");/查找節(jié)點(diǎn)BTNode *FindNode(BTNode *b,ElemType x)BTNode *p;if(b=NULL)return b;else if(b->data=x)return b;elsep=FindNode(b->lchild,x);if(p!=NULL)return p;elseret
8、urn FindNode(b->rchild,x); /求高度 int BTNodeHeight(BTNode *b) int lchildh,rchildh; if(b=NULL) return (0); else lchildh=BTNodeHeight(b->lchild); rchildh=BTNodeHeight(b->rchild); return(lchildh>rchildh)?(lchildh+1):(rchildh+1); /二叉樹的結(jié)點(diǎn)個(gè)數(shù) int NodesCount(BTNode *b)if(b=NULL)return 0;elsereturn
9、 NodesCount(b->lchild)+NodesCount(b->rchild)+1; /先序遍歷遞歸void PreOrder(BTNode *b)if(b!=NULL)printf("%c",b->data);PreOrder(b->lchild);PreOrder(b->rchild);/中序遍歷遞歸void InOrder(BTNode *b)if(b!=NULL)InOrder(b->lchild);printf("%c",b->data);InOrder(b->rchild);/后序遍歷
10、遞歸void PostOrder(BTNode *b)if(b!=NULL)PostOrder(b->lchild);PostOrder(b->rchild);printf("%c",b->data);/層次遍歷void LevelOrder(BTNode *b)BTNode *p;BTNode *quMaxSize;int front,rear;front=rear=-1;rear+;qurear=b;while(front!=rear)front=(front+1)%MaxSize;p=qufront;printf("%c",p-&
11、gt;data);if(p->lchild!=NULL)rear=(rear+1)%MaxSize;qurear=p->lchild;if(p->rchild!=NULL)rear=(rear+1)%MaxSize;qurear=p->rchild;void main()BTNode *b,*p,*lp,*rp;char str="A(B(D,E(H(J,K(L,M(,N),C(F,G(,I)"/根據(jù)樹形圖改寫成的/二叉樹括號(hào)表示法的字符串*str/char str100;scanf("%s",&str);/自行輸入括號(hào)表
12、示的二叉樹CreateBTNode(b,str); /創(chuàng)建樹bprintf("n");printf("輸出二叉樹:");/輸出二叉樹bDispBTNode(b);printf("n");printf("'H'結(jié)點(diǎn):");/找到'H'節(jié)點(diǎn),輸出其左右孩子值p=FindNode(b,'H');printf("n");if (p!=NULL) printf("左孩子節(jié)點(diǎn)的值");printf("%c",p->
13、lchild->data);printf("n");printf("右孩子節(jié)點(diǎn)的值");printf("%c",p->rchild->data);printf("n");/此處輸出p的左右孩子節(jié)點(diǎn)的值printf("n");printf("二叉樹b的深度:%dn",BTNodeHeight(b);/輸出b的高度printf("二叉樹b的結(jié)點(diǎn)個(gè)數(shù):%dn",NodesCount(b);/輸出b的節(jié)點(diǎn)個(gè)數(shù)printf("n"
14、;);printf(" 先序遍歷序列:n");/輸出b的四種遍歷順序printf(" 算法:");PreOrder(b);printf("n");printf(" 中序遍歷序列:n");printf(" 算法:");InOrder(b);printf("n");printf(" 后序遍歷序列:n");printf(" 算法:");PostOrder(b);printf("n"); printf(" 層次遍歷序列:n");printf(" 算法:");LevelOrder(b); printf(
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 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ì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年中國(guó)普通型粉煤機(jī)市場(chǎng)調(diào)查研究報(bào)告
- 2025屆山東省濰坊市高三開學(xué)調(diào)研考-地理試題(含答案)
- 2025年中國(guó)整流器盒數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025-2030年中國(guó)中檔商務(wù)酒店連鎖業(yè)融資發(fā)展可行性及投資前景報(bào)告
- 2025-2030年中國(guó)x光機(jī)行業(yè)未來(lái)發(fā)展趨勢(shì)及前景調(diào)研研究報(bào)告
- 2025-2030年中國(guó)it運(yùn)維管理行業(yè)供需現(xiàn)狀及投資發(fā)展規(guī)劃研究報(bào)告
- 3A游戲行業(yè)深度研究-TakeTwo-曾取凌云志-再見拉滿弓
- 新疆石河子高級(jí)中學(xué)2025屆高三質(zhì)量普查調(diào)研考試英語(yǔ)試題含解析
- 商品預(yù)售房備案合同協(xié)議
- 信陽(yáng)涉外職業(yè)技術(shù)學(xué)院《留學(xué)英語(yǔ)(英)》2023-2024學(xué)年第二學(xué)期期末試卷
- 煤礦的防治水保障體系健全
- 萬(wàn)能角度尺的使用方法
- GB/T 33362-2016金屬材料硬度值的換算
- GB/T 1995-1998石油產(chǎn)品粘度指數(shù)計(jì)算法
- GB 20826-2021潛水員高壓水射流作業(yè)安全規(guī)程
- 南美白對(duì)蝦養(yǎng)殖課件
- 湘潭市歷年中考數(shù)學(xué)試卷,2014-2021年湘潭市中考數(shù)學(xué)近八年真題匯總(含答案解析)
- MPC教育資料和專業(yè)詞匯解析
- (完整版)保溫工藝課件
- 抖音認(rèn)證公函(企業(yè)認(rèn)證申請(qǐng)公函)
- 用人單位常見用工風(fēng)險(xiǎn)防范與應(yīng)對(duì)培訓(xùn)講義(PPT42張)課件
評(píng)論
0/150
提交評(píng)論