2019-09-05 將二叉樹完全靜態(tài)化

struct node{
    typename data;
    node* lchild;
    node* rchild;
}node[maxn];

//節(jié)點的動態(tài)生成可以變?yōu)殪o態(tài)指定:

int index = 0;
int newNode(int v){
    node[index].data = v;
    node[index].lchild = -1;
    node[index].rchild = -1;
    return index++;
} 

//二叉樹查找

void search(int root, int x, int newdata){
    if(root == -1){
        //用-1來代表空樹 
        return ;
        //空樹涡贱,死循環(huán)(遞歸邊界) 
    }
    if(node[root].data == x){
        node[root].data = newdata;
        //如果找到數(shù)據(jù)域為x的節(jié)點,把他修改為newdata 
    } 
    search(node[root].lchild, x, newdata);
    search(node[root].rchild, x, newdata); 
} 

//插入愕把,root為根節(jié)點在數(shù)組中的下標

void insert(int &root, int x){
    //記得加引用
    if(root == -1){
        //空樹拣凹,說明查找失敗,這里就是插入位置(遞歸邊界)
        root = newNode(x);
        return ; 
    } 
    if(由二叉樹性質x應插在左子樹)
        insert(node[root].lchild, x);
    else{
        insert(node[root].rchild, x);
    } 
}

//二叉樹的建立,函數(shù)返回根節(jié)點root的下標

int create(int data[], int n){
    int root = -1;
    for(int i = 0; i < n; i++){
        insert(root, data[i]);
        //將data[0]~data[n-1]插入二叉樹中恨豁; 
    }
    return root;
} 

二叉樹的前序中序后序層序遍歷

//前序
void preorder(int root){
    if(root == -1)
        return ;
        //到達空樹嚣镜,遞歸邊界
    //訪問根節(jié)點root,比如操作:將根節(jié)點輸出
    printf("%d\n", node[root].data);
    //訪問左子樹
    preorder(node[root].lchild);
    //訪問右子樹
    preorder(node[root].rchild); 
} 

//中序
void inorder(int root){
    if(root == -1){
        return ;
    }
    inorder(node[root].lchild);
    printf("%d\n", node[root].data);
    inorder(node[root].rchild);
} 

//后序
void postorder(int root){
    if(root == -1)
        return ;
    postorder(node[root].lchild);
    postorder(node[root].rchild);
    printf("%d\n", node[root].data);
} 

//層序遍歷

void layerorder(int root){
    queue<int> q;
    //此處隊列里放節(jié)點的下標 
    q.push(root);
    //將根節(jié)點地址入隊
    while(!q.empty()){
        int now = q.front();
        q.pop();
        printf("%d ", node[now].data);
        //取出隊首元素并訪問
        if(node[now].lchild != -1)
            q.push(node[root].lchild);
            //左子樹非空
        if(node[now].rchild != -1)
            q.push(node[root].rchild);
            //右子樹非空 
    } 
} 
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末橘蜜,一起剝皮案震驚了整個濱河市菊匿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖跌捆,帶你破解...
    沈念sama閱讀 211,948評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件凡涩,死亡現(xiàn)場離奇詭異,居然都是意外死亡疹蛉,警方通過查閱死者的電腦和手機活箕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來可款,“玉大人育韩,你說我怎么就攤上這事」刖ǎ” “怎么了筋讨?”我有些...
    開封第一講書人閱讀 157,490評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長摸恍。 經(jīng)常有香客問我悉罕,道長,這世上最難降的妖魔是什么立镶? 我笑而不...
    開封第一講書人閱讀 56,521評論 1 284
  • 正文 為了忘掉前任壁袄,我火速辦了婚禮,結果婚禮上媚媒,老公的妹妹穿的比我還像新娘嗜逻。我一直安慰自己,他們只是感情好缭召,可當我...
    茶點故事閱讀 65,627評論 6 386
  • 文/花漫 我一把揭開白布栈顷。 她就那樣靜靜地躺著,像睡著了一般嵌巷。 火紅的嫁衣襯著肌膚如雪萄凤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,842評論 1 290
  • 那天搪哪,我揣著相機與錄音靡努,去河邊找鬼。 笑死噩死,一個胖子當著我的面吹牛颤难,可吹牛的內(nèi)容都是我干的神年。 我是一名探鬼主播已维,決...
    沈念sama閱讀 38,997評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼已日!你這毒婦竟也來了垛耳?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,741評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎堂鲜,沒想到半個月后栈雳,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,203評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡缔莲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,534評論 2 327
  • 正文 我和宋清朗相戀三年哥纫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片痴奏。...
    茶點故事閱讀 38,673評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡蛀骇,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出读拆,到底是詐尸還是另有隱情擅憔,我是刑警寧澤,帶...
    沈念sama閱讀 34,339評論 4 330
  • 正文 年R本政府宣布檐晕,位于F島的核電站暑诸,受9級特大地震影響,放射性物質發(fā)生泄漏辟灰。R本人自食惡果不足惜个榕,卻給世界環(huán)境...
    茶點故事閱讀 39,955評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望芥喇。 院中可真熱鬧笛洛,春花似錦、人聲如沸乃坤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽湿诊。三九已至狱杰,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間厅须,已是汗流浹背仿畸。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留朗和,地道東北人错沽。 一個月前我還...
    沈念sama閱讀 46,394評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像眶拉,于是被迫代替她去往敵國和親千埃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,562評論 2 349

推薦閱讀更多精彩內(nèi)容