leetcode二叉树 根据前中后序重构二叉树——105/889/

一、105. 从前序与中序遍历序列构造二叉树

1.题目

https://leetcode-cn.com/problems/construct-binary-tree-from-preorder-and-inorder-traversal/
给定一棵树的前序遍历 preorder 与中序遍历 inorder。请构造二叉树并返回其根节点。

2.思路

根据前序遍历的路径是根左右,中序遍历的思路是左根右,可以确定:
1.当前区间内的前序遍历的数组第一位是根节点;
2.在中序遍历中找到根节点,根节点左边区间是左子树,根节点右边区间是右子树;
3.递归左右子树

3.代码

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public TreeNode buildTree(int[] preorder, int[] inorder) {
        if (preorder == null || inorder == null) return null;
        return prePost(preorder,  0, preorder.length-1, inorder, 0, inorder.length-1);
    }
    public TreeNode prePost(int[] preorder, int preLeft, int preRight, int[]inorder, int postLeft, int postRight){
        if (preLeft > preRight || postLeft > postRight ) return null;
        // 定位根节点
        TreeNode root = new TreeNode(preorder[preLeft]);
        
        int middle = postLeft;
        int len =0;
        //找到左右子区间
        for(; middle<inorder.length; middle++){
            if(preorder[preLeft] == inorder[middle]){
                break;
                }
            len++;
        }
        root.left = prePost(preorder, preLeft+1, preLeft+len, inorder, postLeft, middle-1);
        root.right = prePost(preorder, preLeft+len+1,preRight, inorder, middle+1, postRight );
            
        
        return root;
    }
    }

二、106. 从中序与后序遍历序列构造二叉树

1.题目

https://leetcode-cn.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/
根据一棵树的中序遍历与后序遍历构造二叉树。

2.思路

前序遍历:根左右
中序遍历:左根右
后序遍历:左右根

3.代码

三、889根据前序和后序遍历构造二叉树

1.题目

https://leetcode-cn.com/problems/construct-binary-tree-from-preorder-and-postorder-traversal/
返回与给定的前序和后序遍历匹配的任何二叉树。
pre 和 post 遍历中的值是不同的正整数。

2.思路

3.代码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值