欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)LeetCode(106.由中序和后序遍歷建立二叉樹)

 更新時間:2021年07月22日 14:31:07   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(106.由中序和后序遍歷建立二叉樹),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 106. Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍歷建立二叉樹

Given inorder and postorder traversal of a tree, construct the binary tree.

Note:
You may assume that duplicates do not exist in the tree.

For example, given

inorder = [9,3,15,20,7]
postorder = [9,15,7,20,3]

Return the following binary tree:

    3
/ \
9  20
/  \
15   7

這道題要求從中序和后序遍歷的結(jié)果來重建原二叉樹,我們知道中序的遍歷順序是左-根-右,后序的順序是左-右-根,對于這種樹的重建一般都是采用遞歸來做,可參見博主之前的一篇博客 Convert Sorted Array to Binary Search Tree。針對這道題,由于后序的順序的最后一個肯定是根,所以原二叉樹的根結(jié)點可以知道,題目中給了一個很關(guān)鍵的條件就是樹中沒有相同元素,有了這個條件就可以在中序遍歷中也定位出根節(jié)點的位置,并以根節(jié)點的位置將中序遍歷拆分為左右兩個部分,分別對其遞歸調(diào)用原函數(shù)。代碼如下:

class Solution {
public:
    TreeNode *buildTree(vector<int> &inorder, vector<int> &postorder) {
        return buildTree(inorder, 0, inorder.size() - 1, postorder, 0, postorder.size() - 1);
    }
    TreeNode *buildTree(vector<int> &inorder, int iLeft, int iRight, vector<int> &postorder, int pLeft, int pRight) {
        if (iLeft > iRight || pLeft > pRight) return NULL;
        TreeNode *cur = new TreeNode(postorder[pRight]);
        int i = 0;
        for (i = iLeft; i < inorder.size(); ++i) {
            if (inorder[i] == cur->val) break;
        }
        cur->left = buildTree(inorder, iLeft, i - 1, postorder, pLeft, pLeft + i - iLeft - 1);
        cur->right = buildTree(inorder, i + 1, iRight, postorder, pLeft + i - iLeft, pRight - 1);
        return cur;
    }
};

上述代碼中需要小心的地方就是遞歸是 postorder 的左右 index 很容易寫錯,比如 pLeft + i - iLeft - 1, 這個又長又不好記,首先我們要記住 i - iLeft 是計算 inorder 中根節(jié)點位置和左邊起始點的距離,然后再加上 postorder 左邊起始點然后再減1。我們可以這樣分析,如果根結(jié)點就是左邊起始點的話,那么拆分的話左邊序列應(yīng)該為空集,此時 i - iLeft 為0, pLeft + 0 - 1 < pLeft, 那么再遞歸調(diào)用時就會返回 NULL, 成立。如果根節(jié)點是左邊起始點緊跟的一個,那么 i - iLeft 為1, pLeft + 1 - 1 = pLeft,再遞歸調(diào)用時還會生成一個節(jié)點,就是 pLeft 位置上的節(jié)點,為原二叉樹的一個葉節(jié)點。

下面來看一個例子, 某一二叉樹的中序和后序遍歷分別為:

Inorder:    11  4  5  13  8  9

Postorder:  11  4  13  9  8  5  

11  4  5  13  8  9      =>          5

11  4  13  9  8  5                /  \

11  4     13   8  9      =>         5

11  4     13  9  8                  /  \

                             4   8

11       13    9        =>         5

11       13    9                    /  \

                             4   8

                            /    /     \

                           11    13    9

Github 同步地址:

https://github.com/grandyang/leetcode/issues/106

類似題目:

Construct Binary Tree from Preorder and Postorder Traversal

Construct Binary Tree from Preorder and Inorder Traversal

參考資料:

https://leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/

https://leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/discuss/758462/C%2B%2B-Detail-Explain-or-Diagram

https://leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/discuss/34803/Sharing-my-straightforward-recursive-solution

到此這篇關(guān)于C++實現(xiàn)LeetCode(106.由中序和后序遍歷建立二叉樹)的文章就介紹到這了,更多相關(guān)C++實現(xiàn)由中序和后序遍歷建立二叉樹內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言數(shù)據(jù)結(jié)構(gòu)不掛科指南之隊列詳解

    C語言數(shù)據(jù)結(jié)構(gòu)不掛科指南之隊列詳解

    這篇博客主要介紹一下隊列的概念,并且采用 C 語言,編寫兩種存儲實現(xiàn)方式:順序存儲和鏈?zhǔn)酱鎯Γ?dāng)然還有常規(guī)的隊列基本操作的實現(xiàn)算法
    2022-09-09
  • C語言中的字符(char)詳細(xì)講解

    C語言中的字符(char)詳細(xì)講解

    本篇文章主要介紹C語言中char的知識,并附有代碼實例,以便大家在學(xué)習(xí)的時候更好的理解,有需要的可以看一下
    2016-07-07
  • C++模板非類型形參的詳細(xì)講解

    C++模板非類型形參的詳細(xì)講解

    這篇文章主要給大家介紹了關(guān)于C++模板非類型形參的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作就有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-11-11
  • 一文詳解如何在VS?Code上搭建C/C++開發(fā)環(huán)境

    一文詳解如何在VS?Code上搭建C/C++開發(fā)環(huán)境

    VSCode是由微軟開發(fā)的一款免費、開源、跨平臺的文本編輯器,它具有許多強大的功能,這篇文章主要給大家介紹了關(guān)于如何在VS?Code上搭建C/C++開發(fā)環(huán)境的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • C++ leetcode之刪除并獲得點數(shù)的示例代碼

    C++ leetcode之刪除并獲得點數(shù)的示例代碼

    這篇文章主要介紹了C++ leetcode之刪除并獲得點數(shù)的示例代碼,本文給大家分享問題解析及解決方案,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • C語言實現(xiàn)像素鳥游戲

    C語言實現(xiàn)像素鳥游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)像素鳥游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++實現(xiàn)二分法的一些細(xì)節(jié)(常用場景)

    C++實現(xiàn)二分法的一些細(xì)節(jié)(常用場景)

    二分法算法思想首先確定有根區(qū)間,將區(qū)間二等分,通過判斷f(x)的符號,逐步將有根區(qū)間縮小,直至有根區(qū)間足夠小,便可求出滿足精度要求的近似值
    2021-07-07
  • C++類基本語法實例分析

    C++類基本語法實例分析

    這篇文章主要介紹了C++類基本語法實例分析,非常適合初學(xué)者學(xué)習(xí)借鑒,需要的朋友可以參考下
    2014-08-08
  • C++中線程池ThreadPool源碼解析

    C++中線程池ThreadPool源碼解析

    線程池(threadpool)作為五大池之一(內(nèi)存池、連接池、線程池、進(jìn)程池、協(xié)程池),線程池的應(yīng)用非常廣泛,不管事客戶端程序還是后臺服務(wù)端,都是提高業(yè)務(wù)處理能力的必備模塊
    2022-09-09
  • C++中四種強制轉(zhuǎn)換方式的區(qū)別

    C++中四種強制轉(zhuǎn)換方式的區(qū)別

    在C++中,有四種不同的強制轉(zhuǎn)換方式,它們分別是靜態(tài)轉(zhuǎn)換、動態(tài)轉(zhuǎn)換、常量轉(zhuǎn)換和重新解釋轉(zhuǎn)換,下面通過示例代碼講解每種轉(zhuǎn)換的區(qū)別,感興趣的朋友跟隨小編一起看看吧
    2023-08-08

最新評論