91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何從前序與中序遍歷序列構造python二叉樹

發布時間:2021-12-13 16:36:11 來源:億速云 閱讀:167 作者:柒染 欄目:大數據

如何從前序與中序遍歷序列構造python二叉樹,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

【題目】

根據一棵樹的前序遍歷與中序遍歷構造二叉樹。

注意: 你可以假設樹中沒有重復的元素。

例如,給出
前序遍歷 preorder = [3,9,20,15,7]
中序遍歷 inorder = [9,3,15,20,7]
返回如下的二叉樹:
 3
   / \
  9  20
    /  \
   15   7
 


【思路】

首先回顧遍歷的順序:前序遍歷是根節點-左子樹-右子樹,中序遍歷是左子樹-根節點-右子樹。

那么前序遍歷數組的第一個元素肯定是根節點,在中序遍歷數組中找到這個元素,則其前一部分是左子樹的元素,其后一部分是右子樹的元素。遞歸即可求解。

注意:前序遍歷+后序遍歷,不能確定唯一的二叉樹!


【代碼】

python版本

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution(object):
    def buildTree(self, preorder, inorder):
        """
        :type preorder: List[int]
        :type inorder: List[int]
        :rtype: TreeNode
        """
        # 前序遍歷,第一個是head
        # 中序遍歷,前一部分是左子樹,后一部分是右子樹
        if len(preorder) == 0:
            return None
        
        node = TreeNode(preorder[0])
        index = inorder.index(preorder[0])
        node.left = self.buildTree(preorder[1: index + 1], inorder[:index])
        node.right = self.buildTree(preorder[index + 1:], inorder[index + 1:])
        return node

【相似題目】

從中序與后序遍歷序列構造二叉樹

解題思路:后序遍歷數組的最后一個元素是根節點的元素,同樣在中序遍歷數組中找到該元素,遞歸生成二叉樹。

根據前序和后序遍歷構造二叉樹

解題思路:直接生成只有右孩子的二叉樹即可滿足條件。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肃北| 浦北县| 金坛市| 中西区| 巴林右旗| 来宾市| 利辛县| 汽车| 上犹县| 慈溪市| 墨竹工卡县| 云浮市| 游戏| 林甸县| 阳朔县| 隆子县| 炎陵县| 玛曲县| 卢湾区| 弋阳县| 修水县| 宜城市| 辉县市| 洛浦县| 噶尔县| 谢通门县| 安西县| 禄丰县| 泽州县| 台南市| 长武县| 双牌县| 巩义市| 吐鲁番市| 临夏县| 上饶县| 察哈| 广德县| 荥经县| 南丰县| 白河县|