遍歷二叉樹口訣 用C語言編程實(shí)現(xiàn)二叉樹的中序遍歷算法?
用C語言編程實(shí)現(xiàn)二叉樹的中序遍歷算法?#Include#Includestruct bitnode*stack[100]struct bitnode//define struct{char datas
用C語言編程實(shí)現(xiàn)二叉樹的中序遍歷算法?
#Include
#Include
struct bitnode*stack[100
]struct bitnode//define struct
{
char data
struct bitnode*lchild,*rchild
}
void later(struct bitnode*&)//preorder create tree
{
char Ch
scanf scanf(%C”,&;Ch)
if(Ch=”)
P=null
else{
P=(struct bitnode*)malloc(sizeof(struct bitnode*)bitnode)
P->data=ch
以后(P->lchild)
以后(P->rchild)
}
void print(struct bitnode*P)//前序遍歷(輸出二叉樹)
{
int i=-1
while(1)
{
while P!=null)
]{
堆棧[i]=P->rchild/*printf(”確定?N“)*/
printf(”%C“,P->data)
P=P->lchild
}
如果(I!=-1)
{
P=stack[i
]i-->
else
return
}
]void main()//main function
]{
]struct bitnode*P,*t
later(P)
print(P)
}
數(shù)據(jù)結(jié)構(gòu)中二叉樹的定義是遞歸的,所以很自然,也很容易理解。
二叉樹的層次遍歷不是遞歸的,而是使用隊(duì)列。數(shù)據(jù)結(jié)構(gòu)中二叉樹的定義如下(不同于圖論中樹的定義):1。這是一個(gè)空集。2它由根節(jié)點(diǎn)及其左右子樹組成,左右子樹滿足二叉樹的定義。