重建二叉树
来源:互联网 发布:淘宝茶叶 编辑:程序博客网 时间:2024/06/06 03:44
题目描述
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
/** * Definition for binary tree * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */import java.util.*;public class Solution { public TreeNode reConstructBinaryTree(int[] pre, int[] in) { HashMap<Integer, Integer> map = new HashMap<Integer,Integer>(); for(int i =0;i<in.length;i++){ map.put(in[i], i); } return reconst(pre, 0, pre.length - 1, in, 0, in.length - 1,map); } public TreeNode reconst(int[] pre, int prei, int prej, int[] in, int ini, int inj,HashMap<Integer, Integer> map) { int num = 0; TreeNode head = null; if (prei <= prej) { head = new TreeNode(pre[prei]); num = map.get(pre[prei])-ini; head.left = reconst(pre, prei + 1, prei + num, in, ini, ini + num - 1,map); head.right = reconst(pre, prei + num + 1, prej, in, ini + num + 1, inj,map); } else { return null; } return head; }}
0 0
- 3.9重建二叉树
- 重建二叉树
- 二叉树重建
- 二叉树重建
- 二叉树的重建
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 二叉树重建
- 二叉树重建
- 重建二叉树
- 重建二叉树
- 重建二叉树
- Android小程序-Walker导航页面(四)
- iscroll使用情况下click事件失效的问题
- 面向接口编程与面向实现编程
- c++内存对齐
- nginx 用户访问站点输入用户名密码验证
- 重建二叉树
- nginx负载均衡安装及测试
- C++实验4-乘法口诀表
- Android 屏幕适配问题归纳
- WWW需要注意的问题
- JS Range HTML文档/文字内容选中、库及应用介绍
- Using SSL in ASP.NET Web API
- 到底什么时候才需要在ObjC的Block中使用weakSelf/strongSelf
- 使用nodejs搭建图片服务器(一)