美文网首页
02_从前序与中序遍历序列构造二叉树

02_从前序与中序遍历序列构造二叉树

作者: butters001 | 来源:发表于2019-11-12 10:51 被阅读0次
# 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
        """
        if not preorder or not inorder:
            return
        root = TreeNode(preorder[0])
        root_index = inorder.index(preorder[0])
        root.left = self.buildTree(preorder[1:root_index+1], inorder[:root_index])
        root.right = self.buildTree(preorder[root_index+1:], inorder[root_index+1:])
        return root

相关文章

网友评论

      本文标题:02_从前序与中序遍历序列构造二叉树

      本文链接:https://www.haomeiwen.com/subject/yyufictx.html