|
| 1 | +# 给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并 |
| 2 | +# 返回其根节点。 |
| 3 | +# |
| 4 | +# |
| 5 | +# |
| 6 | +# 示例 1: |
| 7 | +# |
| 8 | +# |
| 9 | +# 输入: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7] |
| 10 | +# 输出: [3,9,20,null,null,15,7] |
| 11 | +# |
| 12 | +# |
| 13 | +# 示例 2: |
| 14 | +# |
| 15 | +# |
| 16 | +# 输入: preorder = [-1], inorder = [-1] |
| 17 | +# 输出: [-1] |
| 18 | +# |
| 19 | +# |
| 20 | +# |
| 21 | +# |
| 22 | +# 提示: |
| 23 | +# |
| 24 | +# |
| 25 | +# 1 <= preorder.length <= 3000 |
| 26 | +# inorder.length == preorder.length |
| 27 | +# -3000 <= preorder[i], inorder[i] <= 3000 |
| 28 | +# preorder 和 inorder 均 无重复 元素 |
| 29 | +# inorder 均出现在 preorder |
| 30 | +# preorder 保证 为二叉树的前序遍历序列 |
| 31 | +# inorder 保证 为二叉树的中序遍历序列 |
| 32 | +# |
| 33 | +# Related Topics 树 数组 哈希表 分治 二叉树 👍 1663 👎 0 |
| 34 | + |
| 35 | + |
| 36 | +# leetcode submit region begin(Prohibit modification and deletion) |
| 37 | +# Definition for a binary tree node. |
| 38 | +# class TreeNode: |
| 39 | +# def __init__(self, val=0, left=None, right=None): |
| 40 | +# self.val = val |
| 41 | +# self.left = left |
| 42 | +# self.right = right |
| 43 | +class Solution: |
| 44 | + def buildTree(self, preorder: List[int], inorder: List[int]) -> TreeNode: |
| 45 | + def dfs(left, right): |
| 46 | + if left>right: |
| 47 | + return None |
| 48 | + val = preorder.pop(0) |
| 49 | + root = TreeNode(val) |
| 50 | + pos = inorder.index(val) |
| 51 | + root.left = dfs(left, pos-1) |
| 52 | + root.right = dfs(pos+1, right) |
| 53 | + return root |
| 54 | + |
| 55 | + return dfs(0, len(preorder)-1) |
| 56 | + |
| 57 | + |
| 58 | + |
| 59 | + |
| 60 | +# leetcode submit region end(Prohibit modification and deletion) |
0 commit comments