版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p><b> 設(shè)計(jì)說明書</b></p><p> 起止日期:2012 年 12 月 22 日 至 2013 年 01 月 02日</p><p> 年 月 日</p><p><b> 目
2、 錄</b></p><p><b> 一、問題描述1</b></p><p><b> 二、測試數(shù)據(jù)1</b></p><p><b> 三、算法思想1</b></p><p><b> 四、模塊劃分1</b></p&g
3、t;<p><b> 五、數(shù)據(jù)結(jié)構(gòu)2</b></p><p><b> 六、源程序2</b></p><p><b> 七、測試情況7</b></p><p> 八、設(shè)計(jì)體會(huì)及今后的改進(jìn)意見8</p><p><b> 參 考 文 獻(xiàn)
4、9</b></p><p><b> 一、問題描述</b></p><p><b> 1)具體問題描述</b></p><p> 輸入樹的各個(gè)結(jié)點(diǎn),建立排序二叉樹,對(duì)建立的排序二叉樹進(jìn)行層次、先序、中序和后序遍歷并統(tǒng)計(jì)該二叉樹中葉子結(jié)點(diǎn)的數(shù)目等。 </p><p><b>
5、; 2)基本要求</b></p><p><b> (1)用菜單實(shí)現(xiàn)</b></p><p> (2)能夠輸入樹的各個(gè)結(jié)點(diǎn),并能夠輸出用不同方法遍歷的遍歷序列和葉子結(jié)點(diǎn)的數(shù)目。</p><p><b> 二、測試數(shù)據(jù)</b></p><p> ?。?)關(guān)鍵字序列為(45,24,5
6、3,12,37,93)</p><p> ?。?)關(guān)鍵字序列為(44,10,50,3,33,100,22,61,90,78)</p><p><b> 三、算法思想</b></p><p> 因?yàn)槎媾判驑涞牟僮饕鶕?jù)結(jié)點(diǎn)的關(guān)鍵字域來進(jìn)行,所以,首先要定義每個(gè)結(jié)點(diǎn)的數(shù)據(jù)域類型。二叉排序樹的遍歷算法和二叉樹類似,利用鏈表存儲(chǔ)二叉樹,用隊(duì)列實(shí)現(xiàn)
7、層次遍歷,利用棧進(jìn)行非遞歸中序遍歷二叉樹,所以在創(chuàng)建二叉排序樹之前,定義二叉鏈表的存儲(chǔ)表示,對(duì)隊(duì)列、棧進(jìn)行定義 。</p><p> 二叉排序樹的創(chuàng)建是從空的二叉排序樹開始,每輸入一個(gè)結(jié)點(diǎn),經(jīng)過查找操作(二叉排序樹插入的基本過程是查找),,將新的結(jié)點(diǎn)插入到當(dāng)前二叉排序樹的合適位置。首先將二叉排序樹T初始化為空樹,讀入一個(gè)關(guān)鍵字為key的結(jié)點(diǎn),將此結(jié)點(diǎn)插入到二叉排序樹T中,重復(fù)執(zhí)行,直至讀入的關(guān)鍵字key是輸入結(jié)
8、束標(biāo)志。</p><p> 根據(jù)開始定義好的隊(duì)列的定義、操作,用隊(duì)列實(shí)現(xiàn)層次遍歷;按先序次序輸入二叉樹中結(jié)點(diǎn)的值(一個(gè)字符),創(chuàng)建二叉鏈表表示的二叉樹T;分別輸入先序遍歷二叉樹T的遞歸算法、中序遍歷二叉樹T的遞歸算法、后序遍歷二叉樹T的遞歸算法;利用棧進(jìn)行非遞歸中序遍歷二叉樹,非空根指針進(jìn)棧,遍歷左子樹,為空根指針退棧,訪問根結(jié)點(diǎn),遍歷右子樹;遞歸查找葉子數(shù),左子樹的葉子數(shù)加上右葉子數(shù),可以計(jì)算出二叉樹的葉子數(shù)
9、</p><p><b> 四、模塊劃分</b></p><p> ?。?)二叉排序樹的操作要根據(jù)結(jié)點(diǎn)的關(guān)鍵字域來進(jìn)行,其中包括基本操作的函數(shù)有:用隊(duì)列實(shí)現(xiàn)層次遍歷操作函數(shù)、先序遍歷有序二叉樹T的遞歸算法、中序遍歷有序二叉樹T的遞歸算法、后序遍歷有序二叉樹T的遞歸算法、用棧實(shí)現(xiàn)非遞歸中序遍歷有序二叉樹T的算法、求有序二叉樹的葉子數(shù),該抽象數(shù)據(jù)類型文件名為BSTree
10、.h。</p><p> ?。?)void InsertBST(BSTree &T,ElemType e ),其功能是向二叉樹插入新的結(jié)點(diǎn)。</p><p> (3)void CreateBST(BSTree &T ),其功能是創(chuàng)建有序二叉樹。</p><p> ?。?)void lev_traverse(BSTree T),其功能是用隊(duì)列實(shí)現(xiàn)有序
11、二叉樹的層次遍歷。</p><p> ?。?)void PreOrderTraverse(BSTree T),其功能是實(shí)現(xiàn)有序二叉樹T的遞歸先序遍歷。</p><p> ?。?)void InOrderTraverse(BSTree &T),其功能是實(shí)現(xiàn)有序二叉樹T的遞歸中序遍歷。</p><p> ?。?)void PostOrderTraverse(BS
12、Tree T),其功能是實(shí)現(xiàn)有序二叉樹T的遞歸后序遍歷。</p><p> ?。?)void InOrderTraverses(BSTree T),其功能是實(shí)現(xiàn)有序二叉樹T的非遞歸中序遍歷。</p><p> ?。?)int leaf(BSTree T),其功能是求有序二叉樹的葉子數(shù)。</p><p> ?。?0)void main(),主函數(shù),其功能是建立二叉排序
13、樹,調(diào)用以上函數(shù)對(duì)建立的排序二叉樹進(jìn)行層次、先序、中序和后序遍歷并統(tǒng)計(jì)該二叉樹中葉子結(jié)點(diǎn)的數(shù)目。</p><p><b> 五、數(shù)據(jù)結(jié)構(gòu)</b></p><p> ?。?)二叉排序樹的操作里每個(gè)結(jié)點(diǎn)的數(shù)據(jù)域的類型定義(包括關(guān)鍵字項(xiàng)和其他數(shù)據(jù)項(xiàng))</p><p> typedef struct ElemType{</p>&l
14、t;p> int key; //關(guān)鍵字項(xiàng)</p><p> }ElemType;</p><p> typedef struct BSTNode{</p><p> ElemType data;//每個(gè)結(jié)點(diǎn)數(shù)據(jù)域包括關(guān)鍵字項(xiàng)和其他數(shù)據(jù)項(xiàng)</p><p> struct BSTNode *lchild,*rchild;
15、//左右孩子指針</p><p> }BSTNode,*BSTree;</p><p><b> 六、源程序</b></p><p> 源程序存放在文件BSTree.h中</p><p> 文件BSTree.h:</p><p> #include<iostream><
16、/p><p> using namespace std;</p><p> typedef int Status;</p><p> #define OVERFLOW -2</p><p> #define OK 1</p><p> #define TRUE 1 </p><p>
17、#define FALSE 0 </p><p> #define ERROR 0</p><p> #define MAXQSIZE 100 //最大隊(duì)列長度</p><p> typedef struct ElemType{</p><p><b> int key;</b></p>
18、;<p> }ElemType;</p><p> typedef struct BSTNode{</p><p> ElemType data;//結(jié)點(diǎn)數(shù)據(jù)域</p><p> struct BSTNode *lchild,*rchild;//左右孩子指針</p><p> }BSTNode,*BSTree;&l
19、t;/p><p><b> //隊(duì)列定義</b></p><p> typedef struct{ </p><p> BSTree *base; //初始化的動(dòng)態(tài)分配存儲(chǔ)空間的基礎(chǔ) </p><p> int front; //隊(duì)頭指針</p>&l
20、t;p> int rear; //隊(duì)尾指針</p><p> }SqQueue; //順序隊(duì)列的類型名</p><p><b> //棧的定義</b></p><p> typedef struct </p>
21、<p><b> { </b></p><p> BSTree *base;</p><p> BSTree *top;</p><p> int stacksize;</p><p><b> }SqStack;</b></p><p><b&
22、gt; //隊(duì)列的基本操作</b></p><p> Status InitQueue(SqQueue &Q) //隊(duì)列的初始化</p><p><b> {</b></p><p> Q.base=new BSTree[MAXQSIZE];</p><p> if(!Q.base) ex
23、it(OVERFLOW);</p><p> Q.front=Q.rear=0;</p><p> return OK;</p><p><b> }</b></p><p> Status EnQueue(SqQueue &Q,BSTree p) //入隊(duì)函數(shù)</p><p>&
24、lt;b> {</b></p><p> if((Q.rear+1)%MAXQSIZE==Q.front) return ERROR;</p><p> Q.base[Q.rear]=p;</p><p> Q.rear=(Q.rear+1)%MAXQSIZE;</p><p> return OK;</
25、p><p><b> }</b></p><p> Status DeQueue(SqQueue &Q,BSTree &p) //出隊(duì)函數(shù)</p><p><b> {</b></p><p> if(Q.front==Q.rear) return ERROR;</p&
26、gt;<p> p=Q.base[Q.front];</p><p> Q.front=(Q.front+1)%MAXQSIZE;</p><p> return OK;</p><p><b> }</b></p><p><b> //棧的基本操作</b></p&g
27、t;<p> Status InitStack(SqStack &S) //棧的初始化</p><p><b> {</b></p><p> S.base=new BSTree[MAXQSIZE];</p><p> if(!S.base) exit(OVERFLOW);</p><p&g
28、t; S.top=S.base;</p><p> S.stacksize=MAXQSIZE;</p><p> return OK;</p><p><b> }</b></p><p> Status Push(SqStack &S, BSTree P) //入棧</p><
29、;p><b> { </b></p><p> if (S.top-S.base==S.stacksize) return ERROR;</p><p> *S.top++=P;</p><p> return OK;</p><p><b> }</b></p>&
30、lt;p> Status Pop(SqStack &S , BSTree &q) //出棧</p><p><b> { </b></p><p> if (S.top==S.base) </p><p> return ERROR;</p><p> q=*--S.top;<
31、;/p><p> return OK;</p><p><b> }</b></p><p> Status StackEmpty(SqStack &S) //判???lt;/p><p><b> { </b></p><p> if(S.top==S.b
32、ase) </p><p> return TRUE;</p><p><b> else</b></p><p> return FALSE;</p><p><b> }</b></p><p> // 二叉排序樹的插入</p><p&g
33、t; void InsertBST(BSTree &T,ElemType e ) {</p><p> //當(dāng)二叉排序樹T中不存在關(guān)鍵字等于e.key的數(shù)據(jù)元素時(shí),則插入該元素</p><p> if(!T) { //找到插入位置,遞歸結(jié)束</p><p> BSTree S = new BSTNode;
34、 //生成新結(jié)點(diǎn)*S</p><p> S->data = e; //新結(jié)點(diǎn)*S的數(shù)據(jù)域置為e </p><p> S->lchild = S->rchild = NULL;//新結(jié)點(diǎn)*S作為葉子結(jié)點(diǎn)</p><p> T =S; //把新結(jié)點(diǎn)*S鏈接
35、到已找到的插入位置</p><p><b> }</b></p><p> else if (e.key< T->data.key) </p><p> InsertBST(T->lchild, e );//將*S插入左子樹</p><p> else if (e.key> T-&g
36、t;data.key) </p><p> InsertBST(T->rchild, e);//將*S插入右子樹</p><p> }// InsertBST</p><p> // 二叉排序樹的創(chuàng)建</p><p> void CreateBST(BSTree &T ) {</p><p>
37、; //依次讀入一個(gè)關(guān)鍵字為key的結(jié)點(diǎn),將此結(jié)點(diǎn)插入二叉排序樹T中</p><p><b> T=NULL;</b></p><p> ElemType e;</p><p> cin>>e.key; //???</p><p> while(e.key!='\0')
38、{ //0作為輸入結(jié)束標(biāo)志</p><p> InsertBST(T, e); //將此結(jié)點(diǎn)插入二叉排序樹T中</p><p> cin>>e.key;//???</p><p> }//while </p><p> }//CreatBST</p>&l
39、t;p> void lev_traverse(BSTree T) /* 用隊(duì)列實(shí)現(xiàn)層次遍歷 */</p><p><b> { </b></p><p> SqQueue q;</p><p> BSTNode *p;</p><p> InitQueue(q);</p>&l
40、t;p><b> p=T;</b></p><p> EnQueue(q,p);</p><p> while(!(q.rear==q.front))</p><p> { /* 當(dāng)隊(duì)列不空 */</p><p> DeQueue(q,p);</p><p> printf(&q
41、uot;%d ",p->data);</p><p> if(p->lchild!=NULL)</p><p> EnQueue(q,p->lchild);</p><p> if(p->rchild!=NULL)</p><p> EnQueue(q,p->rchild);</p>
42、<p><b> }</b></p><p><b> }</b></p><p> void PreOrderTraverse(BSTree T) //先序遍歷二叉樹T的遞歸算法</p><p><b> { </b></p><p><b&
43、gt; if(T)</b></p><p><b> {</b></p><p> cout << T-> data.key;</p><p> PreOrderTraverse(T->lchild);</p><p> PreOrderTraverse(T->rchi
44、ld);</p><p><b> }</b></p><p><b> }</b></p><p><b> //中序遞歸遍歷</b></p><p> void InOrderTraverse(BSTree &T)</p><p>&
45、lt;b> {</b></p><p><b> if(T)</b></p><p><b> {</b></p><p> InOrderTraverse(T->lchild);</p><p> cout<<T-> data.key;</
46、p><p> InOrderTraverse(T->rchild);</p><p><b> }</b></p><p><b> }</b></p><p> void PostOrderTraverse(BSTree T)//后序遍歷二叉樹T的遞歸算法</p><
47、p><b> { </b></p><p><b> if(T)</b></p><p><b> {</b></p><p> PostOrderTraverse(T->lchild);</p><p> PostOrderTraverse(T->
48、;rchild);</p><p> cout << T->data.key;</p><p><b> }</b></p><p><b> }</b></p><p> void InOrderTraverses(BSTree T) //非遞歸中序遍歷二叉樹<
49、/p><p> { SqStack S;</p><p><b> BSTree p;</b></p><p> BSTree q=new BSTNode;</p><p> InitStack (S); p=T;</p><p> while(p||!StackEmpty(S))<
50、;/p><p><b> { if(p) </b></p><p> {Push(S,p);// p 非空根指針進(jìn)棧,遍歷左子樹</p><p> p=p->lchild;} </p><p><b> else</b></p><p> { Po
51、p(S,q); //p 為空根指針退棧,訪問根結(jié)點(diǎn),遍歷右子樹</p><p> cout<<q->data.key;</p><p> p=q->rchild;}</p><p><b> }</b></p><p> } // while</p><p>
52、int leaf(BSTree T) //求二叉樹的葉子數(shù)</p><p> {if (T==NULL) </p><p> return 0;</p><p><b> else </b></p><p> { if (T->lchild==NULL&&T->rchild==
53、NULL) </p><p> return 1;</p><p><b> else</b></p><p> return leaf(T->lchild)+leaf(T->rchild);</p><p><b> }</b></p><p>
54、return 0; //完成函數(shù)后請(qǐng)刪除此行</p><p><b> }</b></p><p> void main()</p><p><b> {</b></p><p><b> BSTree T;</b></p><p> cou
55、t<<"請(qǐng)輸入若干字符,用回車區(qū)分,以0結(jié)束輸入"<<endl;</p><p> CreateBST(T);</p><p> cout<<"當(dāng)前有序二叉樹層次遍歷結(jié)果為: \n";</p><p> lev_traverse(T);cout<<"\n"
56、;;</p><p> cout<<"當(dāng)前有序二叉樹先序遍歷結(jié)果為: \n";</p><p> PreOrderTraverse(T);cout<<"\n";</p><p> cout<<"當(dāng)前有序二叉樹遞歸中序遍歷結(jié)果為: \n";</p>&l
57、t;p> InOrderTraverse(T);cout<<"\n";</p><p> cout<<"當(dāng)前有序二叉樹后序遍歷結(jié)果為: \n";</p><p> PostOrderTraverse(T);cout<<"\n";</p><p> cout&
58、lt;<"當(dāng)前有序二叉樹非遞歸中序遍歷:\n";</p><p> InOrderTraverses(T);cout<<"\n";</p><p> cout<<"二叉樹的葉子數(shù):"<<leaf(T);cout<<"\n";</p><
59、;p> cout<<endl;</p><p><b> }</b></p><p><b> 七、測試情況</b></p><p> 測試數(shù)據(jù)(1)關(guān)鍵字序列為(45,24,53,12,37,93)的程序輸出為:</p><p> 測試數(shù)據(jù)(2)關(guān)鍵字序列為(44,10
60、,50,3,33,100,22,61,90,78)</p><p><b> 的程序輸出為:</b></p><p> 經(jīng)檢驗(yàn),得出輸出的結(jié)果是正確的。</p><p> 八、設(shè)計(jì)體會(huì)及今后的改進(jìn)意見</p><p> 通過這次課程設(shè)計(jì),我對(duì)數(shù)據(jù)結(jié)構(gòu)中二叉排序樹及二叉樹的知識(shí)掌握地更加熟練,包括如何運(yùn)用隊(duì)列實(shí)現(xiàn)二
61、叉排序樹的層次遍歷,利用棧進(jìn)行非遞歸中序遍歷二叉排序樹,對(duì)二叉排序樹的先序遍歷、中序遍歷、后序遍歷方法了解得更加深入,掌握了二叉排序樹能實(shí)現(xiàn)的一些基本操作。</p><p> 此外,在熟悉課本知識(shí)的同時(shí),學(xué)會(huì)自主學(xué)習(xí)課外知識(shí),課外知識(shí)與課本的知識(shí)相結(jié)合,實(shí)現(xiàn)算法的補(bǔ)充、創(chuàng)新。遇到疑問時(shí),老師、同學(xué)會(huì)熱心的幫我解答,備感溫暖。然而也認(rèn)識(shí)到自己對(duì)數(shù)據(jù)結(jié)構(gòu)課程的學(xué)習(xí)仍不夠深入,仍需進(jìn)一步研究。另外也發(fā)現(xiàn)了自己的許多不
62、足之處:本程序設(shè)計(jì)僅能夠?qū)崿F(xiàn)二叉排序樹的一些基本操作,算法比較簡單。若想用此程序解決生活中的實(shí)際問題,還需另外增加、修改一些程序,這個(gè)方面有待加強(qiáng)。在未來通過對(duì)數(shù)據(jù)結(jié)構(gòu)更深入地學(xué)習(xí),提高自己的能力,靈活運(yùn)用所學(xué)知識(shí)解決生活中的實(shí)際問題。 </p><p><b> 參 考 文 獻(xiàn)</b></p><p> [1]譚浩強(qiáng),C語言程序設(shè)計(jì).北京:清華大學(xué)出版社,200
溫馨提示
- 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. 眾賞文庫僅提供信息存儲(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ù)據(jù)結(jié)構(gòu)二叉排序樹課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉排序樹
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉排序樹的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-二叉排序樹的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)(二叉排序樹的相關(guān)操作)
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)--二叉排序樹調(diào)整為平衡二叉樹
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---二叉排序樹實(shí)現(xiàn)集合的運(yùn)算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---二叉排序樹和平衡二叉樹的判別
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---判別給定的二叉樹是否為二叉排序樹
- 《二叉排序樹的操作》課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)二叉排序樹的實(shí)現(xiàn)__(用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)_)課程設(shè)計(jì)
- 課程設(shè)計(jì)--- 二叉排序樹的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----二叉樹的應(yīng)用
- 二叉樹數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 二叉排序樹實(shí)驗(yàn)
- 二叉排序樹實(shí)驗(yàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉樹及應(yīng)用
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---線索二叉樹
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--二叉樹的算法
- 《數(shù)據(jù)結(jié)構(gòu)遍歷二叉樹》課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論