




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、用遞歸、非遞歸兩種方法遍歷二叉樹數(shù)據(jù)結(jié)構(gòu)(雙語)項(xiàng)目文檔報(bào)告用遞歸、非遞歸兩種方法遍歷二叉樹專 業(yè): 計(jì)算機(jī)科學(xué)與技術(shù) 班 級(jí): 指導(dǎo)教師: 姓 名: 學(xué) 號(hào): 目 錄一、設(shè)計(jì)思想.03二、算法流程圖.04三、源代碼.06四、運(yùn)行結(jié)果.12五、遇到的問題及解決.14六、心得體會(huì).15一、設(shè)計(jì)思想1遞歸:(1)主函數(shù)main()主程序要包括:定義的二叉樹T、建樹函數(shù)、先序遍歷函數(shù)、中序遍歷函數(shù)、后序遍歷函數(shù)。(2)建樹函數(shù)定義一個(gè)輸入的數(shù)是字符型的,當(dāng)ch為空時(shí),T就為空值,否則的話就分配空間給T,T就指向它的結(jié)點(diǎn),然后左指針域指向左孩子,右指針指向右孩子,若還有,繼續(xù)調(diào)用,依次循環(huán)下去,直到c
2、h遇到空時(shí),結(jié)束。最后要返回建立的二叉樹T。(3)先序遍歷函數(shù)根據(jù)先序遍歷規(guī)則,當(dāng)T為非空時(shí),先輸出結(jié)點(diǎn)處的數(shù)據(jù),指針指向左、右孩子,依次進(jìn)行下去。(4) 中序遍歷函數(shù)根據(jù)中序遍歷規(guī)則,當(dāng)T為非空時(shí),先左指針指向左孩子數(shù)據(jù),然后輸出結(jié)點(diǎn)處的數(shù)據(jù),再右指針指向右孩子,依次進(jìn)行下去。(5)后序遍歷函數(shù)根據(jù)后序遍歷規(guī)則,當(dāng)T為非空時(shí),先右指針指向右孩子,然后左指針指向左孩子,最后輸出結(jié)點(diǎn)處的數(shù)據(jù),依次進(jìn)行下去。2.非遞歸:(1)跟遞歸遍歷二叉樹的前提一樣,首先應(yīng)該創(chuàng)建一個(gè)二叉樹,同樣使用先序遞歸的方式創(chuàng)建二叉樹。(2)然后是中序,先序,后序非遞歸遍歷二叉樹。(3)中序非遞歸遍歷二叉樹的思想是:首先是
3、根節(jié)點(diǎn)壓棧,當(dāng)根節(jié)點(diǎn)的左子樹不是空的時(shí)候,左子樹壓棧。直到左子樹為空的時(shí)候,不再壓棧。將棧頂元素出棧,訪問棧頂元素,并將棧頂?shù)挠易訕溥M(jìn)棧。當(dāng)右子樹的左子樹不是空的時(shí)候,左子樹一直進(jìn)棧,直到左子樹為空,則不再進(jìn)棧。重復(fù)上面的操作,直到??盏臅r(shí)候。(4)先序非遞歸遍歷二叉樹的思想是:首先是根節(jié)點(diǎn)進(jìn)棧,然后當(dāng)棧不為空的時(shí)候,將棧頂元素出棧,然后訪問。同時(shí)將出棧元素的右子樹進(jìn)棧,左子樹進(jìn)棧。重復(fù)上面的操作,直到棧為空。(5)后序非遞歸遍歷二叉樹的思想:首先是根節(jié)點(diǎn)進(jìn)棧,當(dāng)根節(jié)點(diǎn)的左子樹不為空的時(shí)候,左子樹進(jìn)棧,直到左為空的時(shí)候,左子樹不再進(jìn)棧。指針指向的是右子樹,當(dāng)右子樹為空的時(shí)候,直接訪問根節(jié)點(diǎn)。當(dāng)
4、右子樹不為空的時(shí)候,則右子樹的指針進(jìn)棧,當(dāng)右子樹的左子樹不為空的時(shí)候,則左也進(jìn)棧,直到左為空。重復(fù)上面的操作,直到棧為空的時(shí)候,則遍歷樹完成。 二、算法流程圖1.遞歸2.非遞歸三、源代碼1.遞歸#include stdio.h#include conio.h#include #includetypedef struct node char data; struct node *lchild, *rchild;BinTnode;typedef BinTnode * BinTree; /定義二叉樹類型的指針/*先序創(chuàng)建二叉樹*/int CreateBinTree(BinTree *T) char
5、ch; *T=(BinTree)malloc(sizeof(BinTnode); if(!*T) printf(overflow); do ch=getchar(); if(ch= ) *T=NULL; return 0; else (*T)-data=ch; CreateBinTree(&(*T)-lchild); CreateBinTree(&(*T)-rchild); return 1; while(ch!=0);/*中序遞歸遍歷*/void InorderTransverse(BinTree s)if (s)InorderTransverse(s-lchild); printf(%c,
6、 s-data);InorderTransverse(s-rchild);/先序遞歸遍歷二叉樹void PreOrderTranverseTree(BinTree s)if (s) printf(%c, s-data);PreOrderTranverseTree(s-lchild);PreOrderTranverseTree(s-rchild);/后序遞歸遍歷二叉樹void PostOrderTranverseTree(BinTree s)if (s) PreOrderTranverseTree(s-lchild);PreOrderTranverseTree(s-rchild);printf(
7、%c, s-data);/*主方法*/void main() BinTree T;printf(請(qǐng)按照先序的順序輸入要?jiǎng)?chuàng)建的樹:n);CreateBinTree(&T); /*中序序列創(chuàng)建二叉樹*/printf(中序遞歸遍歷的序列是:); InorderTransverse(T); printf(n); /先序遞歸遍歷 printf(先序遞歸遍歷的序列是:); PreOrderTranverseTree(T); printf(n); /后序遞歸遍歷 printf(后序遞歸遍歷的序列是:); PostOrderTranverseTree(T); printf(n);2.非遞歸#include s
8、tdio.h#include conio.h#include #include typedef struct node char data; struct node *lchild, *rchild;BinTnode;typedef BinTnode * BinTree; /定義二叉樹類型的指針typedef struct BinTree data100; int top;SeqStack;void initStack(SeqStack *S) S-top =-1;void Push(SeqStack *S,BinTree x) if(S-top=100-1) printf(the stack
9、 is overflow); else S-top=S-top+1; S-dataS-top=x; int Pop(SeqStack *S,BinTree *p) if(S-top=-1) printf(the stack is underflow); return 0; else *p=S-dataS-top; -S-top; return 1; int EmptyStack(SeqStack S) if(S.top=-1) return 1; else return 0; /* 棧不空的情況*/ int GetTop(SeqStack S,BinTree *p) if(S.top=-1)
10、printf(the stack is empty); return 0; else *p=S.dataS.top; return 1; char visit(BinTree p)return (*p).data;/*創(chuàng)建二叉樹*/int CreateBinTree(BinTree *T) char ch; *T=(BinTree)malloc(sizeof(BinTnode); if(!*T) printf(overflow); else do ch=getchar(); if(ch!= ) *T=NULL; return 0; else (*T)-data=ch; CreateBinTre
11、e(&(*T)-lchild); CreateBinTree(&(*T)-rchild); return 1; while(ch!=0); /*中序非遞歸遍歷*/void InorderTransverse(BinTree T) SeqStack S; BinTree p; initStack(&S);/初始化棧 printf(中序非遞歸序列是:); Push(&S,T); /根指針進(jìn)棧 T為指向二叉樹的指針 while(!EmptyStack(S) /棧不是空的情況 while(GetTop(S,&p) & p) Push(&S,p-lchild); /gettop得到的結(jié)果也必須是一棵子樹
12、才行 ,進(jìn)棧應(yīng)該進(jìn)的是樹根的指針 Pop(&S,&p); if(!EmptyStack(S) /printf(%c,visit(p); Pop(&S,&p); printf(%c,visit(p); Push(&S,p-rchild); /*先序非遞歸遍歷*/void PreorderTransverse(BinTree T) SeqStack S; BinTree p; initStack(&S);/初始化棧 Push(&S,T); /根指針進(jìn)棧 T為指向二叉樹的指針 printf(先序非遞歸序列是:); while(!EmptyStack(S) Pop(&S,&p); /根節(jié)點(diǎn)出棧 if(
13、p!=NULL) printf(%c,visit(p); Push(&S,p-rchild); Push(&S,p-lchild);/*后序非遞歸遍歷*/void PostorderTransverse(BinTree T) SeqStack S; BinTree p,q; initStack(&S);/初始化棧 p=T; printf(后序非遞歸序列是:); while(p |!EmptyStack(S) /跳出while循環(huán)的原因是因?yàn)樽笞訕浠蛘哂易訕錇榭樟?if(p!=q) while(p!=NULL) Push(&S,p); if(p-lchild!=NULL) p=p-lchild;
14、 else p=p-rchild; if(EmptyStack(S) break; GetTop(S,&q); if(q-rchild=p) /進(jìn)棧的是右子樹 Pop(&S,&p); printf(%c,visit(p); p=q; else p=q-rchild; /*主方法*/void main() BinTree T;printf(請(qǐng)按照先序的順序輸入創(chuàng)建的樹:n);/*創(chuàng)建樹*/ CreateBinTree(&T);/中序非遞歸遍歷 InorderTransverse(T); printf(n); /先序非遞歸遍歷 PreorderTransverse(T); printf(n); /后序非遞歸遍歷 PostorderTransverse(T);四、運(yùn)行結(jié)果1.遞歸輸入結(jié)果2.非遞歸輸入結(jié)果五、遇到的問題及解決經(jīng)過一個(gè)星期的寫代碼,我遇到了很多問題,并一一解決了,比如:1. 創(chuàng)建二叉樹時(shí):void createBiTree(BiTNode *T)和void createBiTree(BiTNode *&T)沒分清楚區(qū)別。后來查找資料找到void createBiTree(BiTNode *T)是將結(jié)點(diǎn)的指針(地址)傳遞到函數(shù)中進(jìn)行處理void createBiTree(BiTNode *&T是將結(jié)點(diǎn)指針的引用傳遞到函數(shù)處理。才理解清楚。2. 在寫非遞歸算法時(shí),一直邏輯混
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度臨時(shí)保安服務(wù)合同-活動(dòng)期間安全保衛(wèi)
- 2025年度知識(shí)產(chǎn)權(quán)質(zhì)押合同終止及質(zhì)權(quán)實(shí)現(xiàn)協(xié)議
- 產(chǎn)品發(fā)布營銷策略規(guī)劃
- 影視制作發(fā)行合作框架協(xié)議
- 智能能源管理系統(tǒng)建設(shè)投資協(xié)議
- 家具企業(yè)家具設(shè)計(jì)與制造預(yù)案
- 哈他瑜伽介紹課件:哈他瑜伽-身心平衡的藝術(shù)
- 小學(xué)生心理輔導(dǎo)觀后感
- 網(wǎng)絡(luò)購物平臺(tái)合作運(yùn)營協(xié)議書
- 娛樂項(xiàng)目節(jié)目制作授權(quán)協(xié)議
- 電力企業(yè)發(fā)電企業(yè)設(shè)備點(diǎn)檢定修培訓(xùn)教材
- 化學(xué)-浙江省首考2025年1月普通高等學(xué)校招生全國統(tǒng)一考試試題和答案
- 四川省成都市2024-2025學(xué)年高一上學(xué)期期末考試歷史試題(含答案)
- 2025年湖北中煙工業(yè)限責(zé)任公司招聘筆試高頻重點(diǎn)提升(共500題)附帶答案詳解
- 9生物與非生物課件-四年級(jí)下冊(cè)科學(xué)人教鄂教版
- 醫(yī)囑或處方的督導(dǎo)檢查、總結(jié)、反饋及改進(jìn)措施
- 2023年度行政事業(yè)單位內(nèi)部控制報(bào)告編報(bào)講解課件
- 品管圈PDCA案例-介入中心提高手術(shù)患者交接記錄書寫合格率醫(yī)院品質(zhì)管理成果匯報(bào)
- 《土木工程概論》-第3講-土木工程材料-課件
- 《現(xiàn)代漢語》課件-詞義的性質(zhì)和構(gòu)成
- 第十七屆山東省職業(yè)院校技能大賽中職組“西式烹飪”賽項(xiàng)規(guī)程
評(píng)論
0/150
提交評(píng)論