《劍指Offer》樹(shù)考點(diǎn)題解

題目鏈接:把二叉樹(shù)打印成多行

題目簡(jiǎn)述

從上到下按層打印二叉樹(shù),同一層結(jié)點(diǎn)從左至右輸出霉撵。每一層輸出一行洪囤。

題解思路

分層打印二叉樹(shù)喊巍,可以預(yù)見(jiàn)到箍鼓,利用BFS搜索的思想即可做到。

題解代碼

/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};
*/
class Solution {
public:
    vector<vector<int> > Print(TreeNode* pRoot) {
        vector<vector<int> > vv;
        queue<TreeNode*> qu;
        vector<int> v;
        
        if(pRoot == NULL) return vv;
        qu.push(pRoot);
        
        while(!qu.empty())
        {
            int qs = qu.size();
            while(qs--)
            {
                v.push_back(qu.front()->val);
                if(qu.front()->left != NULL) qu.push(qu.front()->left);
                if(qu.front()->right != NULL) qu.push(qu.front()->right);
                qu.pop();
            }
            vv.push_back(v);
            v.clear();
        }
        return vv;
    }
    
};

題目鏈接:按照之字形打印二叉樹(shù)

題目簡(jiǎn)述

請(qǐng)實(shí)現(xiàn)一個(gè)函數(shù)按照之字形打印二叉樹(shù)何暮,即第一行按照從左到右的順序打印铐殃,第二層按照從右至左的順序打印,第三行按照從左到右的順序打印坏逢,其他行以此類推。

題解思路

與上一題類似是整,但是多了一個(gè)在奇數(shù)行(假設(shè)第一行是第零行)反向打印,設(shè)置一個(gè)標(biāo)記flag即可浮入。

題解代碼

/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};
*/
class Solution {
public:
    vector<vector<int> > Print(TreeNode* pRoot) {
        vector<vector<int> > vv;
        queue<TreeNode*> qu;
        vector<int> v;
        int f = 0;
        
        if(pRoot == NULL) return vv;
        qu.push(pRoot);
        
        while(!qu.empty())
        {
            int qs = qu.size();
            while(qs--)
            {
                v.push_back(qu.front()->val);
                if(qu.front()->left != NULL) qu.push(qu.front()->left);
                if(qu.front()->right != NULL) qu.push(qu.front()->right);
                qu.pop();
            }
            f++;
            if(f%2 == 0)
            {
                reverse(v.begin(), v.end());
            }
            vv.push_back(v);
            v.clear();
        }
        return vv;
    }
    
};

題目鏈接:重建二叉樹(shù)

題目簡(jiǎn)述

輸入某二叉樹(shù)的前序遍歷和中序遍歷的結(jié)果羊异,請(qǐng)重建出該二叉樹(shù)彤断。假設(shè)輸入的前序遍歷和中序遍歷的結(jié)果中都不含重復(fù)的數(shù)字易迹。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹(shù)并返回睹欲。

題解思路

做這道題目,前序遍歷和中序遍歷的關(guān)系一定要清楚句伶,前序遍歷的第一個(gè)點(diǎn)一定是根節(jié)點(diǎn),然后我們?cè)谥行虮闅v找到根節(jié)點(diǎn)先嬉,則中序遍歷前面是左子樹(shù)楚堤,后面是右子樹(shù),然后遞歸地進(jìn)行下去身冬。

題解代碼

/**
 * Definition for binary tree
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {
        if(pre.size() == 0 || vin.size() == 0) return NULL;
        TreeNode* root = new TreeNode(pre[0]);
        for(int i=0; i<vin.size(); ++i)
        {
            if(vin[i] == pre[0])
            {
                vector<int> a;
                vector<int> b;
                a.assign(pre.begin()+1, pre.begin()+i+1);
                b.assign(vin.begin(), vin.begin()+i);
                root->left = reConstructBinaryTree(a, b);
                a.clear();
                b.clear();
                a.assign(pre.begin()+i+1, pre.end());
                b.assign(vin.begin()+i+1, vin.end());
                root->right = reConstructBinaryTree(a, b);
            }
        }
        return root;
    }
};

題目鏈接:二叉樹(shù)的下一個(gè)結(jié)點(diǎn)

題目簡(jiǎn)述

給定一個(gè)二叉樹(shù)和其中的一個(gè)結(jié)點(diǎn),請(qǐng)找出中序遍歷順序的下一個(gè)結(jié)點(diǎn)并且返回酥筝。注意,樹(shù)中的結(jié)點(diǎn)不僅包含左右子結(jié)點(diǎn)嘿歌,同時(shí)包含指向父結(jié)點(diǎn)的指針。

題解思路

給定的是中序遍歷丧凤,我們拿到了當(dāng)前節(jié)點(diǎn)步脓,想要找到下一個(gè)節(jié)點(diǎn),這樣有兩個(gè)情況靴患。如果我們有右子樹(shù),那么下一個(gè)節(jié)點(diǎn)一定在右子樹(shù)中:進(jìn)入右子樹(shù)蚁廓,我們重新中序遍歷,下一個(gè)點(diǎn)一定是最左的葉子節(jié)點(diǎn)相嵌。另一種情況是沒(méi)有右子樹(shù),那么下一個(gè)節(jié)點(diǎn)一定是他的父親節(jié)點(diǎn)以上批糟,如果當(dāng)前節(jié)點(diǎn)是父親節(jié)點(diǎn)的右節(jié)點(diǎn),那么要繼續(xù)向上搜索徽鼎,如果是左節(jié)點(diǎn)弹惦,那就是該節(jié)點(diǎn)否淤。

題解代碼

/*
struct TreeLinkNode {
    int val;
    struct TreeLinkNode *left;
    struct TreeLinkNode *right;
    struct TreeLinkNode *next;
    TreeLinkNode(int x) :val(x), left(NULL), right(NULL), next(NULL) {
        
    }
};
*/
class Solution {
public:
    TreeLinkNode* GetNext(TreeLinkNode* pNode)
    {
        if(pNode == NULL) return NULL;
        
        if(pNode->right != NULL)
        {
            pNode = pNode->right;
            while(pNode->left != NULL) pNode = pNode->left;
            return pNode;
        }
        
        while(pNode->next != NULL)
        {
            if(pNode->next->left == pNode)
                return pNode->next;
            pNode = pNode->next;
        }
        
        return NULL;
        
    }
};

題目鏈接:對(duì)稱的二叉樹(shù)

題目簡(jiǎn)述

請(qǐng)實(shí)現(xiàn)一個(gè)函數(shù)石抡,用來(lái)判斷一顆二叉樹(shù)是不是對(duì)稱的。注意助泽,如果一個(gè)二叉樹(shù)同此二叉樹(shù)的鏡像是同樣的,定義其為對(duì)稱的隐解。

題解思路

這道題其實(shí)很簡(jiǎn)單,當(dāng)初做的時(shí)候只是搞錯(cuò)了這個(gè)鏡像的定義煞茫,這個(gè)鏡像只是針對(duì)整個(gè)二叉樹(shù)而言的摄凡,對(duì)于子樹(shù)沒(méi)有要求。

題解代碼


/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};
*/
class Solution {
public:
    bool judge(TreeNode* node1, TreeNode* node2)
    {
        if(node1 == NULL && node2 == NULL) return true;
        if(node1 == NULL || node2 == NULL) return false;
        if(node1->val == node2->val)
        {
            return judge(node1->left, node2->right) && judge(node1->right, node2->left);
        }
        return false;
    }
    bool isSymmetrical(TreeNode* pRoot)
    {
        if(pRoot == NULL) return true;
        return judge(pRoot->left, pRoot->right);
    }

};
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末炸宵,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子土全,更是在濱河造成了極大的恐慌会涎,老刑警劉巖裹匙,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件概页,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡惰匙,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門哑梳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人绘盟,你說(shuō)我怎么就攤上這事鸠真×湔保” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵祭隔,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蠢终,道長(zhǎng),這世上最難降的妖魔是什么寻拂? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任祭钉,我火速辦了婚禮,結(jié)果婚禮上慌核,老公的妹妹穿的比我還像新娘。我一直安慰自己垮卓,他們只是感情好垫桂,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布诬滩。 她就那樣靜靜地躺著灭将,像睡著了一般疼鸟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上庙曙,一...
    開(kāi)封第一講書(shū)人閱讀 49,007評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音吴攒,去河邊找鬼。 笑死欣鳖,一個(gè)胖子當(dāng)著我的面吹牛察皇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播什荣,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼稻爬!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起琉雳,我...
    開(kāi)封第一講書(shū)人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤翠肘,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后辫秧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绪妹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年邮旷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片婶肩。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡探入,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出苗膝,到底是詐尸還是另有隱情植旧,我是刑警寧澤辱揭,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布问窃,位于F島的核電站,受9級(jí)特大地震影響域庇,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜听皿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望庵朝。 院中可真熱鬧又厉,春花似錦覆致、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)腮猖。三九已至,卻和暖如春坪创,著一層夾襖步出監(jiān)牢的瞬間姐赡,已是汗流浹背项滑。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留危喉,地道東北人辜限。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像氧急,于是被迫代替她去往敵國(guó)和親岂座。 傳聞我的和親對(duì)象是個(gè)殘疾皇子费什,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

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

  • 樹(shù) 記錄《劍指offer》中所有關(guān)于樹(shù)的題目鸳址,以及LeetCode中的相似題目泉懦。 相關(guān)題目列表 題目 樹(shù)是一種最常...
    wenmingxing閱讀 1,407評(píng)論 2 13
  • 1. 二叉樹(shù)的深度 分析:如果一棵樹(shù)只有一個(gè)結(jié)點(diǎn)崩哩,它的深度為1。否則樹(shù)的深度就是其左邓嘹、右子樹(shù)深度的較大值再加1酣栈。 ...
    HungerDeng閱讀 521評(píng)論 0 0
  • 樹(shù)的題目通常可以用遞歸解決汹押,遞歸過(guò)程的本質(zhì)是棧矿筝,因而理論上遞歸也可以用循環(huán)加堆棧(或者隊(duì)列)解決 關(guān)于遞歸 遞歸非...
    AcerYoung閱讀 533評(píng)論 0 0
  • 目錄 1、什么是樹(shù) 2妙痹、相關(guān)術(shù)語(yǔ) 3、二叉樹(shù) 3.1琳轿、二叉樹(shù)的類型 3.2利赋、二叉樹(shù)的性質(zhì) 3.3、二叉樹(shù)的結(jié)構(gòu) 3...
    我哈啊哈啊哈閱讀 2,536評(píng)論 0 10
  • 1. 找出數(shù)組中重復(fù)的數(shù)字 題目:在一個(gè)長(zhǎng)度為n的數(shù)組里的所有數(shù)字都在0到n-1的范圍內(nèi)。數(shù)組中某些數(shù)字是重復(fù)的疗涉,...
    BookThief閱讀 1,746評(píng)論 0 2