由于二叉樹是一種特殊的樹,這種特殊的樹,采用順序存儲結(jié)構(gòu)就可以實現(xiàn)。既然是順序存儲結(jié)構(gòu),必然的是通過數(shù)組來實現(xiàn)了。
成都創(chuàng)新互聯(lián)主要從事成都網(wǎng)站制作、做網(wǎng)站、網(wǎng)頁設計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務和政,十余年網(wǎng)站建設經(jīng)驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220
有一種極端情況,就是深度為k的右斜樹,只有k個結(jié)點,如果想要存儲它,就要將它轉(zhuǎn)換為二叉樹,那么必然的需要2^k-1個結(jié)點,這么多結(jié)點中,只有k個結(jié)點是有效數(shù)據(jù),所以,會造成空間的浪費。所以,順序存儲結(jié)構(gòu)只適用于完全二叉樹。
那么,對于那種類似于極端情況的樹,該如何存儲呢?顯然,順序存儲并不適合它。那么,可以考慮采用鏈式存儲。也就是二叉鏈表。因為,二叉樹每個結(jié)點最多有兩個孩子,所以,在設計結(jié)構(gòu)時,有一個變量用來存放數(shù)據(jù),還有兩個指針變量指向左孩子和右孩子。結(jié)構(gòu)定義如下:
typedef struct BiNode{ TElemType data; struct BiTNode *lchild, *rchild; }BiTNode, *BiTree;
分享文章:二叉樹的存儲結(jié)構(gòu)
當前URL:http://www.rwnh.cn/article22/igiojc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、定制網(wǎng)站、云服務器、動態(tài)網(wǎng)站、ChatGPT、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)