數(shù)據(jù)結(jié)構(gòu)與算法分析(c語言)--樹

參考《數(shù)據(jù)結(jié)構(gòu)與算法分析-c語言描述》一書。

1、樹的基本知識

根:沒有父親的節(jié)點。
樹葉:沒有兒子的節(jié)點叫做樹葉,或者葉子結(jié)點。
兄弟:具有相同父親的節(jié)點成為兄弟節(jié)點。
路徑:從節(jié)點A到節(jié)點B的一個序列,該序列上任意相鄰兩個點是父子關系。
路徑的長:路徑上邊的條數(shù)。
深度:對每一個節(jié)點A,A的深度是從根到A的唯一路徑的長。
高度:一個樹的高度是樹到葉子結(jié)點最大的路徑長度。

2、樹的實現(xiàn)

實現(xiàn)樹的一種方法可以是在每一個節(jié)點除數(shù)據(jù)外還有一些指針,使得該節(jié)點的每一個兒子都有一個指針指向它。然后,由于每個節(jié)點的兒子數(shù)可以變化并且事先不知道,因此在數(shù)據(jù)結(jié)構(gòu)中建立到各兒子節(jié)點直接的鏈接是不可行的,因為這樣會產(chǎn)生太多的浪費空間。實際上解法很簡單:將每個節(jié)點的所有兒子都放在樹節(jié)點的鏈表中:

#include <stdio.h>
#include <stdlib.h>

typedef struct TreeNode * PtrToNode;

struct TreeNode
{
    int Element;
    PtrToNode FirstChild;
    PtrToNode NextSibling;
};

這種表示方法想要得到如上圖所示A節(jié)點的所有子節(jié)點,只需要通過FirstChild找到B節(jié)點,根據(jù)B節(jié)點的NextSibling找到B所有的兄弟節(jié)點即可。

如果你喜歡我寫的文章,可以幫忙給小編點個贊或者加個關注,我一定會互粉的!
如果大家對數(shù)據(jù)結(jié)構(gòu)感興趣,歡迎跟小編進行交流,小編微信為sxw2251,加我要寫好備注喲?。?/p>

我的微信
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容