版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 課 程 設(shè) 計(jì)</b></p><p> 1 問題描述及要求4</p><p><b> 1.1問題描述4</b></p><p><b> 1.2任務(wù)要求4</b></p><p> 2 開發(fā)平臺(tái)及所使用軟件4</p>
2、<p> 3 程序設(shè)計(jì)思路5</p><p> 3.1 二叉樹存儲(chǔ)結(jié)構(gòu)設(shè)計(jì)5</p><p> 3.2 題目算法設(shè)計(jì)5</p><p> 3.2.1 建立二叉樹5</p><p> 3.2.2 遍歷二叉樹5</p><p> 3.3.3 按要求格式輸出已建立的二叉樹6</p&
3、gt;<p> 3.3 測(cè)試程序6</p><p><b> 4 調(diào)試報(bào)告6</b></p><p><b> 5 經(jīng)驗(yàn)和體會(huì)7</b></p><p> 6源程序清單及運(yùn)行結(jié)果7</p><p> 6.1源程序清單7</p><p>
4、6.2 運(yùn)行結(jié)果9</p><p><b> 7 參考文獻(xiàn)10</b></p><p> 本科生課程設(shè)計(jì)成績(jī)?cè)u(píng)定表11</p><p><b> 課程設(shè)計(jì)任務(wù)書</b></p><p> 題目: 按層次遍歷二叉樹 <
5、/p><p><b> 初始條件:</b></p><p> 編寫按層次順序(同一層自左至右)遍歷二叉樹的算法。</p><p> ?。?)二叉樹采用二叉鏈表作為存儲(chǔ)結(jié)構(gòu)。</p><p> (2)按嚴(yán)蔚敏《數(shù)據(jù)結(jié)構(gòu)習(xí)題集(C語言版)》p44面題6.69所指定的格式輸出建立的二叉樹。</p><p&
6、gt; ?。?)輸出層次遍歷結(jié)果。</p><p> ?。?)自行設(shè)計(jì)測(cè)試用例。</p><p> 要求完成的主要任務(wù): (包括課程設(shè)計(jì)工作量及其技術(shù)要求,以及說明書撰寫等具體要求)</p><p> 課程設(shè)計(jì)報(bào)告按學(xué)校規(guī)定格式用A4紙打?。〞鴮懀?,并應(yīng)包含如下內(nèi)容: </p><p><b> 1. 問題描述</b&g
7、t;</p><p> 簡(jiǎn)述題目要解決的問題是什么。</p><p><b> 2. 設(shè)計(jì)</b></p><p> 存儲(chǔ)結(jié)構(gòu)設(shè)計(jì)、主要算法設(shè)計(jì)(用類C/C++語言或用框圖描述)、測(cè)試用例設(shè)計(jì);</p><p><b> 3. 調(diào)試報(bào)告</b></p><p> 調(diào)
8、試過程中遇到的問題是如何解決的;對(duì)設(shè)計(jì)和編碼的討論和分析。</p><p> 4. 經(jīng)驗(yàn)和體會(huì)(包括對(duì)算法改進(jìn)的設(shè)想)</p><p> 5. 附源程序清單和運(yùn)行結(jié)果。源程序要加注釋。如果題目規(guī)定了測(cè)試數(shù)據(jù),則運(yùn)行結(jié)果要包含這些測(cè)試數(shù)據(jù)和運(yùn)行輸出。</p><p><b> 說明:</b></p><p> 1.
9、 設(shè)計(jì)報(bào)告、程序不得相互抄襲和拷貝;若有雷同,則所有雷同者成績(jī)均為0分。</p><p> 2. 凡拷貝往年任務(wù)書或課程設(shè)計(jì)充數(shù)者,成績(jī)一律無效,以0分記。</p><p><b> 時(shí)間安排:</b></p><p> 1.第17周完成,驗(yàn)收時(shí)間由指導(dǎo)教師指定</p><p> 2.驗(yàn)收地點(diǎn):實(shí)驗(yàn)中心</
10、p><p> 3.驗(yàn)收內(nèi)容:可執(zhí)行程序與源代碼、課程設(shè)計(jì)報(bào)告書。</p><p> 指導(dǎo)教師簽名: 2013年6月14日</p><p> 系主任(或責(zé)任教師)簽名: 年 月 日</p><p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><
11、;p> ——按層次遍歷二叉樹</p><p><b> 1 問題描述及要求</b></p><p><b> 1.1問題描述</b></p><p> 編寫按層次順序(同一層自左至右)遍歷二叉樹的算法,并將二叉樹按指定格式輸出。(題集p44面題6.69所指定的格式)指定格式如下:</p><
12、;p><b> 圖一:指定輸出格式</b></p><p><b> 1.2任務(wù)要求</b></p><p> 編寫按層次順序(同一層自左至右)遍歷二叉樹的算法。</p><p> ?。?)二叉樹采用二叉鏈表作為存儲(chǔ)結(jié)構(gòu)。</p><p> ?。?)按題集p44面題6.69所指定的格式輸
13、出建立的二叉樹。</p><p> ?。?)輸出層次遍歷結(jié)果。</p><p> ?。?)測(cè)試用例自己設(shè)計(jì)。</p><p> 2 開發(fā)平臺(tái)及所使用軟件</p><p> Windows 7.0 , Visual Studio2010</p><p><b> 3 程序設(shè)計(jì)思路</b>&l
14、t;/p><p> 3.1 二叉樹存儲(chǔ)結(jié)構(gòu)設(shè)計(jì)</p><p> struct BinTreeNode //二叉樹用二叉鏈表存儲(chǔ)</p><p><b> {</b></p><p> char data;
15、 //二叉樹結(jié)點(diǎn)值為字符型</p><p> BinTreeNode* leftchild; //左孩子指針</p><p> BinTreeNode*rightchild; //右孩子指針</p><p><b> }</b></p
16、><p> 3.2 題目算法設(shè)計(jì)</p><p> 3.2.1 建立二叉樹</p><p> void BinTree::creatBinTree(istream& in,BinTreeNode*&subTree)</p><p> //通過輸入流in建立二叉樹</p><p><b>
17、 {</b></p><p> char item;</p><p> cin.get(item);</p><p> if(item!=' ')</p><p><b> {</b></p><p> subTree=new BinTreeNode(item
18、);</p><p> creatBinTree(in,subTree->leftchild);</p><p> creatBinTree(in,subTree->rightchild);</p><p><b> }</b></p><p><b> else </b><
19、;/p><p><b> {</b></p><p> subTree=NULL;</p><p><b> }</b></p><p> }; </p><p> 3.2.2 遍歷二叉樹</p><p&
20、gt; void BinTree::levelOrder(BinTreeNode* subTree) //按層次序遍歷二叉樹</p><p><b> {</b></p><p> queue<BinTreeNode *>q;</p><p> BinTreeNode*p=subTree;</p>&
21、lt;p> q.push(p);</p><p> while(!q.empty()) //若樹非空</p><p><b> {</b></p><p> p=q.front();cout<<visit(p)<<" ";
22、 //輸出隊(duì)頭元素</p><p><b> q.pop();</b></p><p> if(p->leftchild!=NULL){q.push(p->leftchild);} //左子樹非空,入隊(duì)</p><p> if(p->rightchild!=NULL){q.push
23、(p->rightchild);}</p><p><b> }</b></p><p><b> };</b></p><p> 3.3.3 按要求格式輸出已建立的二叉樹</p><p> void Print_BinTree(BinTreeNode* Tree,int i)
24、 //按要求格式輸出已建立的二叉樹</p><p> i表示結(jié)點(diǎn)所在層次。初始i=0</p><p><b> {</b></p><p> BinTreeNode*p=Tree;</p><p> if(p->rightchild) Print_BinTree(Tree->right
25、child,i+1); //遞歸函數(shù)</p><p> for(int j=1;j<=i;j++) cout<<" "; //打印i個(gè)空格表示層次</p><p> cout<<p->data<<endl;</p><p> if(p->le
26、ftchild) Print_BinTree(Tree->leftchild,i+1);</p><p><b> };</b></p><p><b> 3.3 測(cè)試程序</b></p><p> 如圖所示二叉樹,按先序遍歷順序輸入,AB#D##CE#F###。其中”#”代表空格,二叉樹是:A為根節(jié)點(diǎn),A左
27、孩子是B,右孩子是C,B的左孩子為空,右孩子為D,C的左孩子為E,右孩子為空,E的左孩子為空,右孩子為F。根據(jù)以下程序運(yùn)行結(jié)果(見圖4)可知,程序正確運(yùn)行。</p><p> 若輸入AB#D#CE#F###,則程序出現(xiàn)錯(cuò)誤,不能運(yùn)行。(見圖3)</p><p><b> 4 調(diào)試報(bào)告</b></p><p> 1、在建立二叉樹時(shí),輸入的格
28、式一定要正確,沒有孩子的要用空格表示,在測(cè)試用例中, F沒有孩子,要用兩個(gè)空格表示,如果輸入“AB#D##CE#F”則沒有輸出結(jié)果。</p><p> 2、起初編寫輸出程序(void Print_BinTree(BinTreeNode* Tree,int i))的時(shí)候,始終顯示編譯無錯(cuò)誤,但是不能運(yùn)行,出現(xiàn)了一堆有關(guān)內(nèi)存分配錯(cuò)誤的問題。最后發(fā)現(xiàn)沒有將指針指向結(jié)點(diǎn)。經(jīng)改正,運(yùn)行成功。</p>&l
29、t;p><b> 5 經(jīng)驗(yàn)和體會(huì)</b></p><p> 本程序的建立和遍歷二叉樹的程序都比較簡(jiǎn)單,關(guān)鍵在于按要求打印二叉樹。起初一直找不到合適的方法按題目要求打印二叉樹,在和同學(xué)討論了很久之后終于有了思路。在調(diào)試程序的時(shí)候也出現(xiàn)了問題,起初沒有在意輸入方式對(duì)程序運(yùn)行結(jié)果的影響,導(dǎo)致程序無法運(yùn)行,在檢查了很久之后終于找到了問題的所在,對(duì)輸入進(jìn)行了改正,得到了正確的結(jié)果。</
30、p><p> 除此之外,編寫C++程序的過程中,指針時(shí)鐘是個(gè)難點(diǎn)也是個(gè)重點(diǎn),今后要多練習(xí),多理解才行。</p><p> 6源程序清單及運(yùn)行結(jié)果</p><p><b> 6.1源程序清單</b></p><p> #include<iostream></p><p> #inc
31、lude<queue></p><p> using namespace std;</p><p> structBinTreeNode //定義結(jié)構(gòu)體</p><p><b> {</b></p><p> char
32、data;</p><p> BinTreeNode* leftchild;</p><p> BinTreeNode*rightchild;</p><p> BinTreeNode():leftchild(NULL),rightchild(NULL){} </p><p> //結(jié)構(gòu)體可以有構(gòu)造函數(shù)
33、</p><p> BinTreeNode(intx,BinTreeNode*l=NULL,BinTreeNode*r=NULL):data(x),leftchild(l),rightchild(r){}</p><p><b> };</b></p><p> class BinTree </p><p><
34、;b> {</b></p><p><b> private:</b></p><p> BinTreeNode* root;</p><p><b> public:</b></p><p> BinTree():root(NULL){};
35、 //構(gòu)造函數(shù),構(gòu)造一棵空的二叉樹</p><p> BinTreeNode* getroot(){return root;}</p><p> BinTree(const BinTree&s); //復(fù)制構(gòu)造函數(shù)</p><p> ~BinTree(){destroy(root);}
36、 //析構(gòu)函數(shù)</p><p> void destroy(BinTreeNode* subTree); //刪除</p><p> void creatBinTree(istream&in,BinTreeNode* &subTree); //從文件讀入建樹&
37、lt;/p><p> friend istream& operator>>(istream& in,BinTree & Tree); //重載操作:輸入</p><p> void levelOrder(BinTreeNode* subTree); //層次序遍歷</p><p> ch
38、ar visit(BinTreeNode*p){return p->data;}; //取值</p><p><b> };</b></p><p> istream& operator>>(istream& in,BinTree& Tree)
39、 </p><p> //重載操作:輸入并建立一棵二叉樹。in是輸入流對(duì)象</p><p><b> {</b></p><p> Tree.creatBinTree(in,Tree.root);</p><p> return in;</p><p><b> };<
40、;/b></p><p> void BinTree::creatBinTree(istream& in,BinTreeNode*&subTree) </p><p> //從輸入流in輸入二叉樹表示建立對(duì)應(yīng)的二叉鏈表</p><p><b> {</b></p><p> c
41、har item;</p><p> cin.get(item);</p><p> if(item!=' ')</p><p><b> {</b></p><p> subTree=new BinTreeNode(item);</p><p> creatBinTre
42、e(in,subTree->leftchild);</p><p> creatBinTree(in,subTree->rightchild);</p><p><b> }</b></p><p><b> else </b></p><p><b> {</b
43、></p><p> subTree=NULL;</p><p><b> }</b></p><p><b> };</b></p><p> void BinTree::levelOrder(BinTreeNode* subTree)</p><p><
44、;b> {</b></p><p> queue<BinTreeNode *>q;</p><p> BinTreeNode*p=subTree;</p><p> q.push(p);</p><p> while(!q.empty())
45、 //隊(duì)列不空</p><p><b> {</b></p><p> p=q.front();cout<<visit(p)<<" ";</p><p><b> q.pop();</b></p><p> if(p->lef
46、tchild!=NULL){q.push(p->leftchild);} //左子女進(jìn)隊(duì)</p><p> if(p->rightchild!=NULL){q.push(p->rightchild);} //右子女進(jìn)隊(duì)</p><p><b> }</b></p><p><
47、;b> };</b></p><p> Void BinTree::destroy(BinTreeNode*subTree) //釋放空間</p><p><b> {</b></p><p> if(subTree!=NULL)</p><p><
48、;b> {</b></p><p> destroy(subTree->leftchild);</p><p> destroy(subTree->rightchild);</p><p> delete subTree;</p><p><b> }</b></p>
49、<p><b> };</b></p><p> void Print_BinTree(BinTreeNode* Tree,int i) </p><p> //按要求輸出二叉樹,i表示結(jié)點(diǎn)所在層次,初次調(diào)用為0</p><p><b> {</
50、b></p><p> BinTreeNode*p=Tree;</p><p> if(p->rightchild) Print_BinTree(Tree->rightchild,i+1); </p><p> for(int j=1;j<=i;j++) cout<<"";
51、 //打印i個(gè)空格表示層次</p><p> cout<<p->data<<endl; //打印元素,換行</p><p> if(p->leftchild) Print_BinTree(Tree->leftchild,i+1);</p><p>&l
52、t;b> };</b></p><p> int main()</p><p><b> {</b></p><p> BinTree Tree;</p><p><b> int a;</b></p><p><b> int i=0
53、;</b></p><p> cout<<"請(qǐng)按照前序遍歷的方法,輸入初始值,每段空格結(jié)束:"<<endl;</p><p> cin>>Tree;</p><p> BinTreeNode*p=Tree.getroot();</p><p> cout<<
54、;endl;</p><p> cout<<"層序遍歷為:"<<endl;</p><p> Tree.levelOrder(p);</p><p> cout<<endl;</p><p> cout<<"按樹形打印輸出二叉樹"<<e
55、ndl;</p><p> Print_BinTree(p,i);</p><p><b> cin>>a;</b></p><p><b> return 0;</b></p><p><b> }</b></p><p><
56、b> 6.2 運(yùn)行結(jié)果</b></p><p> 圖三:輸入錯(cuò)誤的運(yùn)行結(jié)果</p><p> 圖四:輸入正確的運(yùn)行結(jié)果</p><p><b> 7 參考文獻(xiàn)</b></p><p> [1] 《數(shù)據(jù)結(jié)構(gòu)習(xí)題集(C語言版)》,嚴(yán)蔚敏,吳偉民,米寧編著,清華大學(xué)出版社,出版或修訂時(shí)間:1999年
57、2月</p><p> [2]《數(shù)據(jù)結(jié)構(gòu)(用面向?qū)ο蠓椒ㄅcC++語言描述)(第二版)》,殷人昆主編,清華大學(xué)出版社,出版或修訂時(shí)間:2007年6月</p><p> [3]《C++程序設(shè)計(jì)》,閔聯(lián)營(yíng),何克右編寫,清華大學(xué)出版社,2010年8月</p><p> 本科生課程設(shè)計(jì)成績(jī)?cè)u(píng)定表</p><p> 班級(jí) 姓名: 學(xué)
58、號(hào): </p><p> 注:最終成績(jī)以五級(jí)分制記。優(yōu)(90-100分)、良(80-89分)、中(70-79分)、</p><p> 及格(60-69分)、60分以下為不及格</p><p><b> 指導(dǎo)教師簽名:</b></p><p><b> 2013年 月 日</b><
溫馨提示
- 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ì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉樹的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)之二叉樹的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---二叉樹的遍歷算法集成
- 二叉樹數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---線索二叉樹的生成及其遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉樹的遍歷算法分析與設(shè)計(jì)
- 遍歷二叉樹課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---二叉樹和中序遍歷的演示
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---二叉樹的建立和遍歷的演示
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---計(jì)算二叉樹高度
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----二叉樹的應(yīng)用
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉樹及應(yīng)用
- 主函數(shù)和層次建立二叉樹 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---線索二叉樹
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---二叉樹的操作
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)--二叉排序樹調(diào)整為平衡二叉樹
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉樹的相關(guān)操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--二叉樹的算法
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----二叉樹平衡的判定
評(píng)論
0/150
提交評(píng)論