Skip to content

Commit 3de30e7

Browse files
authored
Merge pull request #162 from karminski/patch-1
Update 0105.Construct-Binary-Tree-from-Preorder-and-Inorder-Traversal.md
2 parents e4505aa + 97928e7 commit 3de30e7

File tree

1 file changed

+15
-0
lines changed

1 file changed

+15
-0
lines changed

website/content/ChapterFour/0100~0199/0105.Construct-Binary-Tree-from-Preorder-and-Inorder-Traversal.md

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -70,6 +70,21 @@ func buildPreIn2TreeDFS(pre []int, preStart int, preEnd int, inStart int, inPos
7070
return root
7171
}
7272

73+
// 解法 2, 直接传入需要的 slice 范围作为输入, 可以避免申请对应 inorder 索引的内存, 内存使用(leetcode test case) 4.7MB -> 4.3MB.
74+
func buildTree(preorder []int, inorder []int) *TreeNode {
75+
if len(preorder) == 0 {
76+
return nil
77+
}
78+
root := &TreeNode{Val:preorder[0]}
79+
for pos, node := range inorder {
80+
if node == root.Val {
81+
root.Left = buildTree(preorder[1:pos+1], inorder[:pos])
82+
root.Right = buildTree(preorder[pos+1:], inorder[pos+1:])
83+
}
84+
}
85+
return root
86+
}
87+
7388
```
7489

7590

0 commit comments

Comments
 (0)