數(shù)據(jù)結(jié)構(gòu)二叉樹遍歷及線索化后各種操作絕對無錯_第1頁
數(shù)據(jù)結(jié)構(gòu)二叉樹遍歷及線索化后各種操作絕對無錯_第2頁
數(shù)據(jù)結(jié)構(gòu)二叉樹遍歷及線索化后各種操作絕對無錯_第3頁
數(shù)據(jù)結(jié)構(gòu)二叉樹遍歷及線索化后各種操作絕對無錯_第4頁
數(shù)據(jù)結(jié)構(gòu)二叉樹遍歷及線索化后各種操作絕對無錯_第5頁
已閱讀5頁,還剩4頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論