由前序遍历数组和中序遍历数组重建二叉树
2018-03-06 15:50
288 查看
在Leetcode中有一道题目105. Construct Binary Tree from Preorder and Inorder Traversal是要求由前序遍历数组和中序遍历数组重建二叉树的,以下是一段比较高效的代码以及注释。/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
class Solution {
private int pre = 0;
private int in = 0;
public TreeNode buildTree(int[] preorder, int[] inorder) {
return helper(preorder, inorder, null);
}
//rootVal构造左子树时到达父结点; 构造右子树时到达父结点的父结点
public TreeNode helper(int[] preorder, int[] inorder, Integer rootVal){
if(pre >= preorder.length || in >= inorder.length || (rootVal != null && rootVal == inorder[in]))
return null;
TreeNode node = new TreeNode(preorder[pre++]);
node.left = helper(preorder, inorder, node.val); //构造左子树,以当前结点为界
in++; //与pre++操作相对应
node.right = helper(preorder, inorder, rootVal); //构造右子树, 以当前结点的父结点为界
return node;
}
}
//98%//例子: 每个在前序数组中依次出现的结点, 在中序数组中, 该结点左边的为左子树, 右边直到其父结点的为右子树
//前序遍历: 1 2 4 7 3 5 6 8
//中序遍历: 4 7 2 1 5 3 8 6
//对于结点1,其左子树由4 7 2构成, 右子树由5 3 8 6构成
//对于结点2,其左子树由4 7构成, 右子树为空(2和1之间没有结点)
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
class Solution {
private int pre = 0;
private int in = 0;
public TreeNode buildTree(int[] preorder, int[] inorder) {
return helper(preorder, inorder, null);
}
//rootVal构造左子树时到达父结点; 构造右子树时到达父结点的父结点
public TreeNode helper(int[] preorder, int[] inorder, Integer rootVal){
if(pre >= preorder.length || in >= inorder.length || (rootVal != null && rootVal == inorder[in]))
return null;
TreeNode node = new TreeNode(preorder[pre++]);
node.left = helper(preorder, inorder, node.val); //构造左子树,以当前结点为界
in++; //与pre++操作相对应
node.right = helper(preorder, inorder, rootVal); //构造右子树, 以当前结点的父结点为界
return node;
}
}
//98%//例子: 每个在前序数组中依次出现的结点, 在中序数组中, 该结点左边的为左子树, 右边直到其父结点的为右子树
//前序遍历: 1 2 4 7 3 5 6 8
//中序遍历: 4 7 2 1 5 3 8 6
//对于结点1,其左子树由4 7 2构成, 右子树由5 3 8 6构成
//对于结点2,其左子树由4 7构成, 右子树为空(2和1之间没有结点)
相关文章推荐
- 题目:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。
- 刷题之路----根据前序遍历和中序遍历或者后序遍历和中序遍历重建二叉树
- 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5
- 二叉树--由前序遍历和中序遍历重建二叉树
- 剑指offer 6---由前序遍历和中序遍历重建二叉树
- 《剑指Offer》 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。
- 题目:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树
- 已知二叉树的前序遍历和中序遍历的结果,重建二叉树
- 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。
- 前序遍历和中序遍历重建二叉树
- 由前序遍历和中序遍历重建二叉树(前序序列:1 2 3 4 5 6 - 中序序列:3 2 4 1 6 5)
- 由前序遍历和中序遍历重建二叉树
- 据前序遍历和中序遍历重建二叉树
- 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5
- 由前序遍历和中序遍历重建二叉树
- 输入某二叉树的前序遍历和中序遍历的结果,重建该二叉树
- 根据前序遍历和中序遍历重建二叉树
- 由前序遍历和中序遍历重建二叉树
- 【二叉树】由前序遍历和中序遍历重建二叉树
- ~由前序遍历和中序遍历重建二叉树~