剑指offer面试题7-重建二叉树

剑指offer面试题7:重建二叉树

题目:输入某个二叉树的前序和中序遍历结果,重建该二叉树,例如输入前序遍历:12473568,中序遍历:47215386,则重建二叉树如下

这道题目使用递归的话思路就非常简单,函数接收两个长度一样的遍历结果,根据前序遍历第一个节点在中序遍历当中的位置,就可以判断出左子树和右子树分别有哪些节点,然后再分别把左子树和右子树当做另一个新的二叉树进行相同的方法递归,当传入的前序遍历和中序遍历都只有一个节点时说明到达递归终点,此时返回根节点即可

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
function TreeNode(x) {
this.val = x;
this.left = null;
this.right = null;
}
function reConstructBinaryTree(pre, vin){
let root //定义根节点
if(pre.length === 1){
root = {
val : pre,
left : null,
right : null
}
}
else{
let index = vin.indexOf(pre[0])
if(index === 0){
root = {
val : pre[0],
left : null,
right : reConstructBinaryTree(pre.slice(index + 1) ,vin.slice(index + 1))
}
}
else if(index === vin.length - 1){
root = {
val : pre[0],
left : reConstructBinaryTree(pre.slice(1, index + 1) ,vin.slice(0, index)),
right : null
}
}
else{
root = {
val : pre[0],
left : reConstructBinaryTree(pre.slice(1, index + 1) ,vin.slice(0, index)),
right : reConstructBinaryTree(pre.slice(index + 1) ,vin.slice(index + 1))
}
}

}
return root
}
  • Copyright: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.

扫一扫,分享到微信

微信分享二维码
  • Copyrights © 2020-2024 AuroraAksnesOs

请我喝杯咖啡吧~

支付宝
微信