C語言二叉樹的遍歷示例介紹
在本算法中先利用先序遍歷創(chuàng)建了樹,利用了遞歸的算法使得算法簡(jiǎn)單,操作容易,本來無printf("%c的左/右子樹:", ch);的語句,但由于計(jì)算機(jī)需要輸入空格字符來判斷左右子樹,為了減少人為輸入的失誤,特地加入這條語句,以此保證準(zhǔn)確率。
#include<stdio.h>
#include<stdlib.h>
#define OK 1
#define ERROR 0
#define OVERFLOW 3
typedef int Status;
typedef int Boolean;
typedef char TElemType;
typedef struct BiTNode{
TElemType data;
struct BiTNode *lchild, *rchild;
}BiTNode, *BiTree;
//創(chuàng)建二叉樹函數(shù)
Status CreateBiTree(BiTree &T){
TElemType ch;
scanf("%c", &ch);
getchar();
if(ch == ' '){ T = NULL;}
else {
if( !(T=(BiTree)malloc(sizeof(BiTNode))))(exit(OVERFLOW));
T->data = ch;
printf("%c的左子樹:", ch);
CreateBiTree(T->lchild);
printf("%c的右子樹:", ch);
CreateBiTree(T->rchild); }
return OK;
}
//先序遍歷函數(shù)
Status PreOrderTraverse(BiTree T, Status (* Visit)(TElemType e)){
if(T){
if(Visit(T->data)){
if(PreOrderTraverse(T->lchild, Visit)){
if(PreOrderTraverse(T->rchild, Visit)){
return OK;
}
}
}
return ERROR;
}
else {return OK;}
}
//中序遍歷函數(shù)
Status InOrderTraverse(BiTree T, Status (* Visit)(TElemType e)){
if(T){
if(PreOrderTraverse(T->lchild, Visit) ){
if(Visit(T->data)){
if(PreOrderTraverse(T->rchild, Visit) ){
return OK;
}
}
}
return ERROR;
}
else {
return OK;
}
}
//后序遍歷函數(shù)
Status PosOrderTraverse(BiTree T, Status (* Visit)(TElemType e)){
if(T){
if(PreOrderTraverse(T->lchild, Visit) ){
if(PreOrderTraverse(T->rchild, Visit) ){
if(Visit(T->data)){return OK;
}
}
}
return ERROR;}
else {return OK;
}
}
//輸出二叉樹函數(shù)
Status PrintElement(TElemType e){
printf("%c",e);
return OK;
}
//主函數(shù)
int main(){
BiTree T;
printf("輸入根結(jié)點(diǎn):");
CreateBiTree(T);
printf("先序遍歷:\n");
PreOrderTraverse(T, PrintElement);
printf("\n");
printf("中序遍歷:\n");
InOrderTraverse(T, PrintElement);
printf("\n");
printf("后序遍歷:\n");
PosOrderTraverse(T, PrintElement);
return 0;
}遍歷操作有四種,其不同在于對(duì)根結(jié)點(diǎn)的訪問順序不同。在先序遍歷中,首先訪問根結(jié)點(diǎn),然后遞歸地做左子樹的先序遍歷,然后是右子樹的遞歸先序遍歷。 在中序遍歷中,遞歸地對(duì)左子樹進(jìn)行中序遍歷,訪問根結(jié)點(diǎn),最后遞歸中序遍歷右子樹。在后序遍歷中,遞歸地對(duì)左子樹和右子樹進(jìn)行后序遍歷,然后訪問根結(jié)點(diǎn)。先序,中序,后序遍歷就是對(duì)于根節(jié)點(diǎn)的訪問順序。
但無論哪種遍歷方式,遞歸的方法是最簡(jiǎn)便,最直接,最簡(jiǎn)單的算法。
運(yùn)行截圖:

到此這篇關(guān)于C語言二叉樹的遍歷示例介紹的文章就介紹到這了,更多相關(guān)C語言二叉樹內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解C/C++中const關(guān)鍵字的用法及其與宏常量的比較
簡(jiǎn)單的說const關(guān)鍵字修飾的變量具有常屬性,也就是說它所修飾的變量不能被修改,下文給大家介紹C/C++中const關(guān)鍵字的用法及其與宏常量的比較,需要的朋友可以參考下2017-07-07
C語言16進(jìn)制與ASCII字符相互轉(zhuǎn)換
大家好,本篇文章主要講的是C語言16進(jìn)制與ASCII字符相互轉(zhuǎn)換,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
C++11 強(qiáng)類型枚舉相關(guān)總結(jié)
這篇文章主要介紹了C++11 強(qiáng)類型枚舉的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用c++11,感興趣的朋友可以了解下2021-02-02
Qt利用QScroller實(shí)現(xiàn)home界面滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了Qt如何利用QScroller實(shí)現(xiàn)home界面滑動(dòng)效果,文中的實(shí)現(xiàn)過程講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-11-11

