二叉樹建立的輸入問題

2021-08-28 09:35:01 字數 721 閱讀 1289

這幾天在看資料結構的二叉樹,被二叉樹建立時的輸入問題困擾很久。二叉樹的建立一般使用遞迴演算法,將所有節點的資料一股腦的輸入,遞迴無法停止,二叉樹就無法建立。

感謝此博文,原來我們在輸入節點資料的時候,必須輸入空閒葉子節點,並用特殊符號標記,比如上述的博文的空閒葉子節點採用『0』作為標記符,就能完整建立二叉樹。

修改後的**,親測有效:

#include#includeusing namespace std;

struct node;};

node *input()

return p;

}void pre(node *root)

}void in(node *root)

}void post(node *root)

}int nodenum(node *root)

else

}int leafnum(node *root)

else if((root->left==null)&&(root->right==null))

else }

int deep(node *root)

else }

int main()

{ node *p;

p=new node;

p=input();

cout<

建立二叉樹 後序建立二叉樹

由後序遍歷可知,輸入順序是左結點 右結點 子樹根結點 比如輸入如下樹 ab cde 輸入序列為 e d b c a 思路 使用棧,對左結點和右結點進行壓棧 1.當輸入遇到非 且棧中元素大於等於2,則可以確定乙個小三角樹形,並將這個樹根作為下乙個小三角樹形的乙個子節點 2.當輸入遇到非 但棧中元素小於...

二叉樹的建立 遍歷1 建立二叉樹

談二叉樹,如果二叉樹都沒有正確的建立出來,那豈不是紙上談兵!括號表示式 表示方法 1.括號 括號內的東西是括號前的元素的孩子 2.逗號 逗號是為了區分左右孩子 演算法分析 給出乙個如上的括號表示式 a b d g e,f 再利用棧這個資料結構,分析一下 掃瞄整個括號表示的字串,這個字串中只有四種字元...

建立二叉樹

今天看到了乙個資料結構的筆試題目,他要求寫出建立二叉樹的程式。我想練習練習,所以想了一下其大致的思路,記錄如下 題目的要求很簡單,給出乙個字串序列 比如說a b d,e h j,k l,m n c f,g i 然後要求按照其規則建立二叉樹,題目不難但是卻花費了我不少的時間 第一步,我想到的是需要什麼...