




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、.數(shù)據(jù)結(jié)構(gòu)課程實(shí)驗(yàn)報(bào)告實(shí)驗(yàn)名稱樹(shù)和二叉樹(shù)實(shí)驗(yàn)序號(hào)5實(shí)驗(yàn)日期姓 名院系班 級(jí)學(xué) 號(hào)專 業(yè)指導(dǎo)教師成 績(jī)教師評(píng)語(yǔ)一、實(shí)驗(yàn)?zāi)康暮鸵?1)掌握樹(shù)的相關(guān)概念,包括樹(shù)、結(jié)點(diǎn)的度、樹(shù)的度、分支結(jié)點(diǎn)、葉子結(jié)點(diǎn)、兒子結(jié)點(diǎn)、雙親結(jié)點(diǎn)、樹(shù)的深度、森林等定義。(2)掌握樹(shù)的表示,包括樹(shù)形表示法、文氏圖表示法、凹入表示法和括號(hào)表示法等。(3)掌握二叉樹(shù)的概念,包括二叉樹(shù)、滿二叉樹(shù)和完全二叉樹(shù)的定義。(4)掌握二叉樹(shù)的性質(zhì)。(5)重點(diǎn)掌握二叉樹(shù)的存儲(chǔ)結(jié)構(gòu),包括二叉樹(shù)順序存儲(chǔ)結(jié)構(gòu)和鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。(6)重點(diǎn)掌握二叉樹(shù)的基本運(yùn)算和各種遍歷算法的實(shí)現(xiàn)。(7)掌握線索二叉樹(shù)的概念和相關(guān)算法的實(shí)現(xiàn)。(8)掌握哈夫曼樹(shù)的定義、哈夫曼
2、樹(shù)的構(gòu)造過(guò)程和哈夫曼編碼產(chǎn)生方法。(9)掌握并查集的相關(guān)概念和算法。(10)靈活掌握運(yùn)用二叉樹(shù)這種數(shù)據(jù)結(jié)構(gòu)解決一些綜合應(yīng)用問(wèn)題。二、實(shí)驗(yàn)項(xiàng)目摘要1編寫(xiě)一程序,實(shí)現(xiàn)二叉樹(shù)的各種基本運(yùn)算,并在此基礎(chǔ)上設(shè)計(jì)一個(gè)主程序完成如下功能:(1) 輸出二叉樹(shù)b;(2) 輸出H結(jié)點(diǎn)的左、右孩子結(jié)點(diǎn)值;(3) 輸出二叉樹(shù)b的深度;(4) 輸出二叉樹(shù)b的寬度;(5) 輸出二叉樹(shù)b的結(jié)點(diǎn)個(gè)數(shù);(6) 輸出二叉樹(shù)b的葉子結(jié)點(diǎn)個(gè)數(shù)。2編寫(xiě)一程序,實(shí)現(xiàn)二叉樹(shù)的先序遍歷、中序遍歷和后序遍歷的各種遞歸和非遞歸算法,以及層次遍歷的算法。三、實(shí)驗(yàn)預(yù)習(xí)內(nèi)容二叉樹(shù)存儲(chǔ)結(jié)構(gòu),二叉樹(shù)基本運(yùn)算(創(chuàng)建二叉樹(shù)、尋找結(jié)點(diǎn)、找孩子結(jié)點(diǎn)、求高度、輸出
3、二叉樹(shù))三、實(shí)驗(yàn)結(jié)果與分析 7-1#include #include #define MaxSize 100typedef char ElemType;typedef struct nodeElemType data;struct node *lchild;struct node *rchild; BTNode;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+;
4、Sttop=p;k=1; break;case ):top-;break;case ,:k=2; break; default:p=(BTNode *)malloc(sizeof(BTNode);p-data=ch;p-lchild=p-rchild=NULL; if (b=NULL) b=p;else switch(k) case 1:Sttop-lchild=p;break;case 2:Sttop-rchild=p;break;j+;ch=strj;BTNode *FindNode(BTNode *b,ElemType x)BTNode *p;if (b=NULL) return NUL
5、L;else if (b-data=x) return b;elsep=FindNode(b-lchild,x);if (p!=NULL) return p;else return FindNode(b-rchild,x);BTNode *LchildNode(BTNode *p) return p-lchild;BTNode *RchildNode(BTNode *p) return p-rchild;int BTNodeDepth(BTNode *b) int lchilddep,rchilddep; if (b=NULL) return(0); else lchilddep=BTNode
6、Depth(b-lchild); rchilddep=BTNodeDepth(b-rchild);return (lchilddeprchilddep)? (lchilddep+1):(rchilddep+1); void DispBTNode(BTNode *b)if (b!=NULL)printf(%c,b-data);if (b-lchild!=NULL | b-rchild!=NULL)printf();DispBTNode(b-lchild);if (b-rchild!=NULL) printf(,);DispBTNode(b-rchild);printf();int BTWidth
7、(BTNode *b)struct int lno;BTNode *p; QuMaxSize;int front,rear;int lnum,max,i,n;front=rear=0; if (b!=NULL) rear+;Qurear.p=b;Qurear.lno=1;while (rear!=front)front+;b=Qufront.p;lnum=Qufront.lno;if (b-lchild!=NULL)rear+;Qurear.p=b-lchild;Qurear.lno=lnum+1;if (b-rchild!=NULL)rear+;Qurear.p=b-rchild;Qurea
8、r.lno=lnum+1;max=0;lnum=1;i=1;while (i=rear)n=0;while (imax) max=n;return max;elsereturn 0;int Nodes(BTNode *b)int num1,num2; if (b=NULL) return 0; else if (b-lchild=NULL & b-rchild=NULL) return 1; else num1=Nodes(b-lchild); num2=Nodes(b-rchild); return (num1+num2+1);int LeafNodes(BTNode *b)int num1
9、,num2; if (b=NULL) return 0; else if (b-lchild=NULL & b-rchild=NULL) return 1; else num1=LeafNodes(b-lchild); num2=LeafNodes(b-rchild); return (num1+num2);void main()BTNode *b,*p,*lp,*rp;CreateBTNode(b,A(B(D,E(H(J,K(L,M(,N),C(F,G(,I); printf(輸出二叉樹(shù):);DispBTNode(b);printf(n);printf(H結(jié)點(diǎn):);p=FindNode(b,
10、H);if (p!=NULL)lp=LchildNode(p);if (lp!=NULL) printf(左孩子為%c ,lp-data);elseprintf(無(wú)左孩子 );rp=RchildNode(p);if (rp!=NULL) printf(右孩子為%c,rp-data);elseprintf(無(wú)右孩子 );printf(n);printf(二叉樹(shù)b的深度:%dn,BTNodeDepth(b);printf(二叉樹(shù)b的寬度:%dn,BTWidth(b);printf(二叉樹(shù)b的結(jié)點(diǎn)個(gè)數(shù):%dn,Nodes(b);printf(二叉樹(shù)b的葉子結(jié)點(diǎn)個(gè)數(shù):%dn,LeafNodes(b);
11、7-2#include #include #define MaxSize 100typedef char ElemType;typedef struct nodeElemType data;struct node *lchild;struct node *rchild; BTNode;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; b
12、reak;case ):top-;break;case ,:k=2; break; default:p=(BTNode *)malloc(sizeof(BTNode);p-data=ch;p-lchild=p-rchild=NULL; if (b=NULL) b=p;else switch(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-rchil
13、d!=NULL)printf();DispBTNode(b-lchild);if (b-rchild!=NULL) printf(,);DispBTNode(b-rchild);printf();void PreOrder(BTNode *b)if (b!=NULL) printf(%c ,b-data);PreOrder(b-lchild);PreOrder(b-rchild);void PreOrder1(BTNode *b)BTNode *StMaxSize,*p; int top=-1; if (b!=NULL) top+; Sttop=b; while (top-1) p=Sttop
14、; top-; printf(%c ,p-data); if (p-rchild!=NULL) top+; Sttop=p-rchild; if (p-lchild!=NULL) top+; Sttop=p-lchild;printf(n);void InOrder(BTNode *b)if (b!=NULL) InOrder(b-lchild);printf(%c ,b-data);InOrder(b-rchild);void InOrder1(BTNode *b)BTNode *StMaxSize,*p;int top=-1;if (b!=NULL)p=b;while (top-1 | p
15、!=NULL)while (p!=NULL)top+;Sttop=p;p=p-lchild;if (top-1)p=Sttop;top-;printf(%c ,p-data);p=p-rchild;printf(n);void PostOrder(BTNode *b)if (b!=NULL) PostOrder(b-lchild);PostOrder(b-rchild);printf(%c ,b-data);void PostOrder1(BTNode *b)BTNode *StMaxSize;BTNode *p;int flag,top=-1;if (b!=NULL)dowhile (b!=
16、NULL)top+;Sttop=b;b=b-lchild;p=NULL;flag=1;while (top!=-1 & flag)b=Sttop;if (b-rchild=p)printf(%c ,b-data);top-;p=b;elseb=b-rchild;flag=0; while (top!=-1);printf(n); 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-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;CreateBTNode(b,A(B(D,E(H(J,K(L,M(,N),C(F,G(,I); printf(二叉樹(shù)b:);DispBTNode(b);printf(n);printf(先序遍歷序列:n);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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 預(yù)防燙傷課件
- 植物的光感應(yīng)與生長(zhǎng):試題及答案
- 2024年CPSM企業(yè)文化試題及答案
- 2024年CPMM成果展示試題及答案
- 電子商務(wù)設(shè)計(jì)師如何提升數(shù)據(jù)分析能力試題及答案
- 2025年鋼結(jié)構(gòu)用H型鋼項(xiàng)目建議書(shū)
- 2025年脈沖電磁閥項(xiàng)目投資風(fēng)險(xiǎn)評(píng)估報(bào)告
- 樹(shù)木的生長(zhǎng)與環(huán)境因素試題及答案
- 2025年無(wú)機(jī)基礎(chǔ)化學(xué)原料項(xiàng)目發(fā)展計(jì)劃
- 各國(guó)物流法規(guī)的比較分析試題及答案
- 2023學(xué)年杭州市高一語(yǔ)文下學(xué)期期中聯(lián)考試卷附答案解析
- 電磁學(xué)第四版課后答案解析梁燦彬
- 農(nóng)產(chǎn)品直供新模式
- 2025內(nèi)蒙古西部新能源開(kāi)發(fā)有限公司招聘工作人員20人筆試參考題庫(kù)附帶答案詳解
- 2025年常州機(jī)電職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)技能考試題庫(kù)完整版
- 15 一分鐘(核心素養(yǎng)公開(kāi)課一等獎(jiǎng)創(chuàng)新教案)
- 湖北省十一校2025屆高三上學(xué)期第一次聯(lián)考(一模)數(shù)學(xué)試題【含答案解析】
- 2025年山東省職教高考(車(chē)輛維修專業(yè))綜合知識(shí)高頻必練考試題庫(kù)400題含答
- 《動(dòng)畫(huà)速寫(xiě)(第3版)》中職全套教學(xué)課件
- 2025屆新高考語(yǔ)文熱點(diǎn)沖刺復(fù)習(xí):新高考作文教學(xué)及備考策略
- 2025年安徽六安市“政錄企用”人才引進(jìn)工作招錄300人高頻重點(diǎn)提升(共500題)附帶答案詳解
評(píng)論
0/150
提交評(píng)論