博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
树一:重建二叉树
阅读量:7282 次
发布时间:2019-06-30

本文共 1772 字,大约阅读时间需要 5 分钟。

/**

 * 题目:重建二叉树
 * 描述:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。
 *   例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
 * 解决方案:思路:   

  1. 先由前序遍历找到根节点,然后根据根节点和中序遍历,在中序遍历数组中,根节点前面的数字就是左边树的所有节点,根节点后面的数字就是右边树的所有节点。 
  2. 得到新的两个前序遍历序列:前序遍历序列中,根据在中序遍历数组中的得到的根节点下标,可以得到左子树的前序遍历和右子树的前序遍历。
  3. 得到新的两个中序遍历序列: 中序遍历序列中,根据①中,可以得到所有左边树节点和右边树所有节点,并分别构成新的中序遍历序列
  4. 递归操作①②③;,分别得到左子树和右子树的根节点,就是①中根节点的左节点和右节点;

* 注:

 * 先序遍历:先访问根节点,再左子树,再右子树

 * 中序遍历:先访问左子树,再根节点,再右子树
 * 后序遍历:先访问左子树,再右子树,再根节点
 * */

public class One {        /**     * 根据前序遍历和中序遍历构建二叉树     * @param preOrder 前序遍历     * @param ps 开始位置     * @param pe 结束位置     * @param inOrder 中序遍历序列     * @param is 开始位置     * @param ie 结束位置     * @return 节点     * */    public static BinaryTreeNode construct(int[] preOrder,int ps,int pe,int[] inOrder,int is,int ie) {        //如果前序遍历的开始位置大于结束位置,说明已经处理到叶子节点了        if(ps > pe) {            return null;        }        //前序遍历的第一个数字为当前的根节点        int value = preOrder[ps];        //定义一个中间变量  代表中序遍历的开始索引        int index = is;        //在中序遍历中寻找根节点的位置,然后分割中序序列,得到新的左边树中序序列和右边树中序序列        while(index 
ie) { throw new RuntimeException("Error----构建新的根节点"); } BinaryTreeNode node = new BinaryTreeNode(); node.var = value;     //前序遍历数组和中序遍历数组中,左子树+根的数量处于数组的前面位置     //比如 前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6} ,前四个数字1、2、4、7就是左子树和根,只是顺序不一样。     //所以 preOrder中,需要从ps+1位置开始,ps+index-is结束。 node.left = construct(preOrder, ps+1,ps+index-is, inOrder, is, index-1); node.right = construct(preOrder, ps+index-is+1, pe, inOrder, index+1, ie); return node; } static class BinaryTreeNode{ int var; BinaryTreeNode left; BinaryTreeNode right; }}

 

转载于:https://www.cnblogs.com/ZeGod/p/9969469.html

你可能感兴趣的文章
有意思的网站
查看>>
max3232
查看>>
linux读写ntfs
查看>>
x264 编码器选项分析 (x264 Codec Strong and Weak Points) 1
查看>>
lintcode:带环链表
查看>>
10最好的开放源移动工具的工作场所
查看>>
【转载】为什么不建议<=3G的情况下使用CMS GC
查看>>
CentOS中基于不同版本安装重复包的解决方案
查看>>
vim:查看当前的配置文件名称和地址
查看>>
javaweb学习总结二十二(servlet开发中常见的问题汇总)
查看>>
Nginx 做系统的前端反向proxy
查看>>
Win8 Metro(C#)数字图像处理--2.49Zhang二值图像细化算法
查看>>
嵌入 Office ,doc|docx|xls|xlsx|ppt|pptx|pdf|等
查看>>
Cut Down QtWebkit Library
查看>>
在Windows下Hunchentoot的启动
查看>>
网新恒天2013年校园招聘笔试
查看>>
推荐五星级C语言学习网站
查看>>
windows 下的命令行工具。。
查看>>
使用自定义的BaseAdapter实现LIstView的展示
查看>>
对RTMP视频流进行BitmapData.draw()出错的解决办法
查看>>