題解:二叉排序樹的建立和遍歷(malloc函數(shù)和typedf)

第二次修改柏卤,增加了new和二叉樹的一些基本操作省容。


題目描述

輸入一系列整數(shù)抖拴,建立二叉排序數(shù),并進(jìn)行前序腥椒,中序阿宅,后序遍歷。

輸入

輸入第一行包括一個(gè)整數(shù)n(1<=n<=100)笼蛛。接下來的一行包括n個(gè)整數(shù)洒放。

輸出

可能有多組測(cè)試數(shù)據(jù),對(duì)于每組數(shù)據(jù)滨砍,將題目所給數(shù)據(jù)建立一個(gè)二叉排序樹往湿,并對(duì)二叉排序樹進(jìn)行前序妖异、中序和后序遍歷。每種遍歷結(jié)果輸出一行领追。每行最后一個(gè)數(shù)據(jù)之后有一個(gè)空格他膳。

自己不熟悉的地方:

  • 用到了malloc函數(shù):

1.malloc函數(shù)是一種分配長(zhǎng)度為num_bytes字節(jié)的內(nèi)存塊的函數(shù),可以向系統(tǒng)申請(qǐng)分配指定size個(gè)字節(jié)的內(nèi)存空間绒窑。
2.malloc的全稱是memory allocation棕孙,中文叫動(dòng)態(tài)內(nèi)存分配,當(dāng)無法知道內(nèi)存具體位置的時(shí)候些膨,想要綁定真正的內(nèi)存空間蟀俊,就需要用到動(dòng)態(tài)的分配內(nèi)存。
3.返回類型是 void* 類型订雾。void* 表示未確定類型的指針肢预。C,C++規(guī)定,void* 類型可以通過類型轉(zhuǎn)換強(qiáng)制轉(zhuǎn)換為任何其它類型的指針葬燎。
4.相關(guān):

作用 代碼
malloc函數(shù)原型 extern void *malloc(unsigned int num_bytes);
malloc函數(shù)頭文件 #include <stdlib.h>或者#include <malloc.h>

謝謝提示误甚,這里用new建立也可以,還簡(jiǎn)單一些谱净。百度了一下malloc和new的區(qū)別,放這了擅威。https://www.cnblogs.com/shilinnpu/p/8945637.html

  • 用到了typedef定義新的結(jié)構(gòu)體

大佬總結(jié)很詳細(xì):https://blog.csdn.net/superhoy/article/details/53504472


代碼實(shí)現(xiàn)如下:

| 

#include <iostream>
#include <malloc.h>
using namespace std;
 
typedef struct Bnode
{
    int data;
    struct Bnode *Ichild,*Rchild; 
} Bnode,*Btree;
 
void Creat_BST(Btree &T,int a)
{
    if(T==NULL)
    {
        T=(Btree)malloc(sizeof(Bnode));  //強(qiáng)制轉(zhuǎn)換
        T->Ichild=NULL;
        T->Rchild=NULL;
        T->data=a;
    }
    else{
        if(a>T->data){
            Creat_BST(T->Rchild,a);
        }
        if(a<T->data){
            Creat_BST(T->Ichild,a);
        }
        else return;
    }
}
 
int preOrder(Btree T)    //先序遍歷
{
    if(T==NULL) return 0;
    cout<<T->data<<" ";
    preOrder(T->Ichild);
    preOrder(T->Rchild);
}
 
int inOrder(Btree T)     //中序遍歷
{
    if(T==NULL)  return 0;
    inOrder(T->Ichild);
    cout<<T->data<<" ";
    inOrder(T->Rchild);
}
 
int postOrder(Btree T)  //后序遍歷
{
    if(T==NULL)  return 0;
    postOrder(T->Ichild);
    postOrder(T->Rchild);
    cout<<T->data<<" ";
}
 
int main()
{
    int n;
    while(cin>>n)
    {
        Btree T=NULL;
        while(n)
        {
            int a;
            n--;
            cin>>a;
            Creat_BST(T,a);
        }
        preOrder(T);
        cout<<endl;
        inOrder(T);
        cout<<endl;
        postOrder(T);
        cout<<endl;
    }
}

二叉樹節(jié)點(diǎn)總數(shù)目:

int Nodenum(Btree T)
{
    if(!T) return 0;
    else return  1+(Nodenum(T->Ichild)+Nodenum(T->Rchild)) ;
}

二叉樹深度:(和高度同理)

int DepthOfTree(Btree T)
{
    if(!T) return 0;
    else 
    return  DepthOfTree(T->Ichild)>DepthOfTree(T->Rchild)? 1+DepthOfTree(T->Ichild):1+DepthOfTree(T->Rchild);
}

二叉樹葉子節(jié)點(diǎn)數(shù):

int Leafnum(Btree T)
{
    if(!T) return 0;
    else if((T->Ichild== NULL) && (T->Rchild == NULL) ) return 1;
    else return  (Leafnum(T->Ichild)+Leafnum(T->Rchild)) ;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末壕探,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子郊丛,更是在濱河造成了極大的恐慌李请,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件厉熟,死亡現(xiàn)場(chǎng)離奇詭異导盅,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)揍瑟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門白翻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人绢片,你說我怎么就攤上這事滤馍。” “怎么了底循?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵巢株,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我熙涤,道長(zhǎng)阁苞,這世上最難降的妖魔是什么困檩? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮那槽,結(jié)果婚禮上悼沿,老公的妹妹穿的比我還像新娘。我一直安慰自己倦炒,他們只是感情好显沈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著逢唤,像睡著了一般拉讯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鳖藕,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天魔慷,我揣著相機(jī)與錄音,去河邊找鬼著恩。 笑死院尔,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的喉誊。 我是一名探鬼主播邀摆,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼伍茄!你這毒婦竟也來了栋盹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤敷矫,失蹤者是張志新(化名)和其女友劉穎例获,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體曹仗,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡榨汤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了怎茫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片收壕。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖遭居,靈堂內(nèi)的尸體忽然破棺而出啼器,到底是詐尸還是另有隱情,我是刑警寧澤俱萍,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布端壳,位于F島的核電站,受9級(jí)特大地震影響枪蘑,放射性物質(zhì)發(fā)生泄漏损谦。R本人自食惡果不足惜岖免,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望照捡。 院中可真熱鬧颅湘,春花似錦、人聲如沸栗精。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽悲立。三九已至鹿寨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間薪夕,已是汗流浹背脚草。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留原献,地道東北人馏慨。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像姑隅,于是被迫代替她去往敵國和親写隶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

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