二叉樹(Binary tree)是樹形結(jié)構(gòu)的一個(gè)重要類型。許多實(shí)際問題抽象出來的數(shù)據(jù)結(jié)構(gòu)往往是二叉樹形式,即使是一般的樹也能簡單地轉(zhuǎn)換為二叉樹,而且二叉樹的存儲結(jié)構(gòu)及其算法都較為簡單,因此二叉樹顯得特別重要。二叉樹特點(diǎn)是每個(gè)節(jié)點(diǎn)最多只能有兩棵子樹,且有左右之分。所以實(shí)現(xiàn)二叉樹的遍歷用雙鏈表比較簡單。
實(shí)現(xiàn)一個(gè)數(shù)組的二叉樹插入遍歷data_type arr[] = {35,45,23,44,33,65,13,54};
創(chuàng)建一個(gè)二叉樹雙鏈表根據(jù)二叉樹的特點(diǎn),我們定義一個(gè)包含左右孩子和本身數(shù)據(jù)的結(jié)構(gòu)體作為根結(jié)點(diǎn)
typedef int data_type;
typedef struct treeNode
{struct treeNode *lchild;
struct treeNode *rchild;
data_type data;
}tree;
寫一個(gè)申請根節(jié)點(diǎn)的函數(shù),返回申請到的空間的首地址
tree *createTree(data_type item)
{tree *pRoot = NULL;
pRoot = (tree *)malloc(sizeof(tree));
if(pRoot == NULL)
{return NULL;
}
memset(pRoot,0,sizeof(tree));
pRoot->data = item;
return pRoot;
}
插入結(jié)點(diǎn)插入結(jié)點(diǎn)時(shí),我們要先判斷插入的值和根結(jié)點(diǎn)值誰更大,比根結(jié)點(diǎn)大我們將他插入到左孩子中,否則插入到右孩子中
int insertTree(tree *pRoot,data_type item)
{tree *pNew = NULL;
pNew = (tree *)malloc(sizeof(tree));
if(pNew == NULL)
{return -1;
}
memset(pNew,0,sizeof(tree));
pNew->data = item;
while(1)
{ if(pNew->data< pRoot->data)//插入左孩子處
{ if(pRoot->lchild != NULL)
{ pRoot = pRoot->lchild;
}
else
{ pRoot->lchild = pNew;
return 0;
}
}
else
{ if(pRoot->rchild != NULL)//插入右孩子處
{ pRoot = pRoot->rchild;
}
else
{ pRoot->rchild = pNew;
return 0;
}
}
}
}
三種遍歷二叉樹的遍歷分為以下三種:
先序遍歷:遍歷順序規(guī)則為【根左右】
中序遍歷:遍歷順序規(guī)則為【左根右】
后序遍歷:遍歷順序規(guī)則為【左右根】
利用遞歸思想,實(shí)現(xiàn)二叉樹的遍歷。會在末尾講解二叉樹的遞歸
前序遍歷//前序遍歷
int preOrder(tree *pRoot)
{if(pRoot == NULL)
{return -1;
}
//先訪問根結(jié)點(diǎn)
printf("%d ",pRoot->data);
//訪問左子樹
preOrder(pRoot->lchild);
//訪問右子樹
preOrder(pRoot->rchild);
}
中序遍歷//中序遍歷
int inOrder(tree *pRoot)
{if(pRoot == NULL)
{return -1;
}
inOrder(pRoot->lchild);
printf("%d ",pRoot->data);
inOrder(pRoot->rchild);
}
后序遍歷//后序遍歷
int postOrder(tree *pRoot)
{if(pRoot == NULL)
{return -1;
}
postOrder(pRoot->lchild);
postOrder(pRoot->rchild);
printf("%d ",pRoot->data);
}
遞歸思想拿我們的前序遍歷來講解
if(pRoot == NULL)
{return -1;
}
//先訪問根結(jié)點(diǎn)
printf("%d ",pRoot->data); // 1
//訪問左子樹
preOrder(pRoot->lchild); // 2
//訪問右子樹
preOrder(pRoot->rchild); // 3
接下來用一張自己畫的圖來詳細(xì)說明
以上是我對遞歸思想的理解,如有錯(cuò)誤請指正!
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級服務(wù)器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧
網(wǎng)頁名稱:二叉樹的三種遍歷(雙鏈表實(shí)現(xiàn))以及遞歸思想的個(gè)人理解--C語言-創(chuàng)新互聯(lián)
地址分享:http://jinyejixie.com/article22/dhcojc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、網(wǎng)站內(nèi)鏈、面包屑導(dǎo)航、網(wǎng)站排名、營銷型網(wǎng)站建設(shè)、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容