成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

如何從前序與中序遍歷序列構(gòu)造python二叉樹

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

創(chuàng)新互聯(lián)于2013年成立,先為高青等服務(wù)建站,高青等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為高青企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

【題目】

根據(jù)一棵樹的前序遍歷與中序遍歷構(gòu)造二叉樹。

注意: 你可以假設(shè)樹中沒有重復(fù)的元素。

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

【思路】

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

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

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

【代碼】

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

【相似題目】

從中序與后序遍歷序列構(gòu)造二叉樹

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

根據(jù)前序和后序遍歷構(gòu)造二叉樹

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

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。

本文名稱:如何從前序與中序遍歷序列構(gòu)造python二叉樹
文章地址:http://jinyejixie.com/article28/gggccp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司手機網(wǎng)站建設(shè)、電子商務(wù)、搜索引擎優(yōu)化外貿(mào)網(wǎng)站建設(shè)、App設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計
肥西县| 明光市| 廊坊市| 霍城县| 勃利县| 兰考县| 巴彦淖尔市| 营口市| 镶黄旗| 景谷| 米林县| 嵊泗县| 灵璧县| 新绛县| 呈贡县| 嘉祥县| 苏尼特右旗| 秦皇岛市| 蒙自县| 青阳县| 冕宁县| 崇礼县| 新泰市| 巴南区| 海原县| 旅游| 榆树市| 晋宁县| 嘉峪关市| 三明市| 明水县| 宿松县| 金华市| 广丰县| 天峨县| 得荣县| 新乡县| 舒城县| 海城市| 福建省| 乐东|