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