




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、實驗二 二叉樹的存儲結(jié)構(gòu)及各種運(yùn)算的實現(xiàn)第一題:#include "stdio.h"#include "malloc.h"#define maxsize 66typedef int datatype;typedef struct node datatype data ; struct node *lchild,*rchild; bitree;bitree *Qmaxsize;bitree *creatree()char ch;int front,rear;bitree *root,*s;root=NULL;front=1;rear=0;ch=getcha
2、r();while (ch!='#')s=NULL;if(ch!='')s=malloc(sizeof(bitree);s->data=ch;s->lchild=NULL;s->rchild=NULL;rear+;Qrear=s;if(rear=1) root=s;elseif (s&&Qfront)if(rear%2=0)Qfront->lchild=s;elseQfront->rchild=s;if(rear%2=1)front+;ch=getchar();return root;preorder(bitree
3、*t) /前if (t)printf(" %c ",t->data);preorder(t->lchild);preorder(t->rchild);inorder(bitree *t) /中if (t)inorder(t->lchild);printf(" %c ",t->data);inorder(t->rchild);postorder(bitree *t) /后if (t)postorder(t->lchild);postorder(t->rchild);printf(" %c "
4、;,t->data);int height(bitree *t) /高度int hl,hr;if(!t) return 0;elsehl=height(t->lchild);hr=height(t->rchild);return (hl>hr?hl:hr)+1);int leaf(bitree *t) /葉子 static int s; if(t) leaf(t->lchild); leaf(t->rchild); if(t->lchild=NULL&&t->rchild=NULL) s=s+1; return s;main()b
5、itree *t;int x,y;printf("輸入數(shù)據(jù),以#做結(jié)尾:n");t=creatree();printf("preorder:t");preorder(t);printf("ninorder:t");inorder(t);printf("npostorder:t");postorder(t);x=height(t);y=leaf(t);printf("n高度:%d",x);printf("n葉子:%d",y); printf("n");第二題
6、:#include <stdio.h>#include <malloc.h>#define maxsize 40typedef struct node char data; struct node *lchild,*rchild; int ltag,rtag; bitree;bitree *Qmaxsize; /*隊列*/bitree *pre=NULL;bitree *creatree() char ch; int front,rear; /*隊頭、隊尾*/ bitree *root,*s; root=NULL; /*空樹*/ front=1; rear=0; /*空
7、隊*/ ch=getchar(); while(ch!='#') s=NULL; if(ch!='') /*建立新結(jié)點(diǎn)*/ s=(bitree *)malloc(sizeof(bitree); s->data=ch; s->lchild=s->rchild=NULL; s->ltag=s->rtag=0; rear+; Qrear=s; /*入隊*/ if(rear=1) root=s; else if(s && Qfront) /*孩子、雙親均非空*/ if(rear%2=0) Qfront->lchild=
8、s; else Qfront->rchild=s; if(rear%2=1) front+; /*出隊*/ ch=getchar(); return root;/中序遍歷;void inorder(bitree *t) if(t) inorder(t->lchild); printf("%c",t->data); inorder(t->rchild); /中序線索劃;void INTHREAD(bitree *p)if(p!=NULL) INTHREAD(p->lchild); if(p->lchild=NULL) p->ltag=
9、1; if(p->rchild=NULL) p->rtag=1; if(pre!=NULL) if(pre->rtag=1) pre->rchild=p; if(p->ltag=1) p->lchild=pre; pre=p; INTHREAD(p->rchild); /中序線索二叉樹中求中序后繼結(jié)點(diǎn);bitree * inordernext (bitree *p) bitree *q; if(p->rtag=1) return p->rchild; else q=p->rchild; while(q->ltag=0) q=q->lchild; return q; /中序遍歷;void traverseinthread(bitree *p)if(p!=NULL) while (p->ltag=0 ) p=p->lchild; do printf("%c",p->data); p=inordernext(p); while(p!=NULL); void main() bitree *t; t=creatree(); printf("中序遍歷結(jié)果是:n:"); inorder
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 小學(xué)生硬筆書法偏旁課件
- 保山車輛油耗管理辦法
- 企業(yè)銷售傭金管理辦法
- 公司前期資金管理辦法
- 企業(yè)考評管理辦法試行
- 倉鼠排泄管理辦法視頻
- 人行代收業(yè)務(wù)管理辦法
- 臨沂師承機(jī)構(gòu)管理辦法
- 企業(yè)商業(yè)年金管理辦法
- 豐城漁網(wǎng)收繳管理辦法
- CJ/T 410-2012隔油提升一體化設(shè)備
- 石油化工監(jiān)理工作報告
- 天津市和平區(qū)五十五中2025屆數(shù)學(xué)八下期末調(diào)研試題含解析
- 醫(yī)學(xué)科研成果轉(zhuǎn)化實踐分享
- 汽車4S店安全教育培訓(xùn)
- 采購專業(yè)知識培訓(xùn)
- 2025年云南省衛(wèi)生健康系統(tǒng)事業(yè)單位招聘基礎(chǔ)知識類精練題(附答案)
- 牙隱裂鑒別診斷
- 酒店評優(yōu)方案
- 預(yù)見性護(hù)理及早期風(fēng)險識別課件
- 食堂原材料采購管理方案及食品保存管理方案
評論
0/150
提交評論