第四题:根据前序和中序遍历结果重建二叉树(Arrays常用方法)

本文介绍了一种通过前序和中序遍历结果重建二叉树的方法,利用递归技术定位根节点,划分左右子树,并提供了完整的Java实现代码。

输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{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.Arrays;

public class Solution {
    public TreeNode reConstructBinaryTree(int [] pre,int [] in) {
        if(pre.length<1 || in.length<1)
        	return null;
        TreeNode treeNode = new TreeNode(pre[0]);
        for(int i=0;i<pre.length;i++){
        	if(pre[0] == in[i]){
        		treeNode.left = reConstructBinaryTree(Arrays.copyOfRange(pre, 1, i+1),Arrays.copyOfRange(in, 0, i));
        		treeNode.right = reConstructBinaryTree(Arrays.copyOfRange(pre, i+1, pre.length),Arrays.copyOfRange(in, i+1, in.length));
        	}
        }
    	return treeNode;
    }
}
知识补充:Arrays(数组)常用方法

用法:import java.util.Arrays;   Arrays.方法

方法:

1、sort() 默认升序

   默认由小到大排序,不只对于数值型的可以排序,对于字符串等也都可以进行排序

                         重写Conparator实现降序,返回正数,就会对调这两个数,这里也就是,如果o2>o1,降序的话要对调的

        Arrays.sort(list,newComparator<Integer>() {
            publicintcompare(Integer o1, Integer o2) {
                returno2 - o1;
            }

        });

      如果是ArrayList或者Linkedlist把

       import java.util.Collections;   Arrays改成Collections.sort


二维数组排序,记得看下滴滴的俄罗斯套娃问题

2、binarySearch()

  对已排序(从小到大排序的)的数组进行二元搜索,如果找到指定的值就返回其所在的索引位置,否则返回负值

3、fill()

   将数组的元素全部设定为指定的值
4、equals()

   比较两个数组元素中的元素值是否全部相等,如果是返回true,否则返回false,适用于一维数组,多维数组用deepEquals()用法同equals;
5、deepEquals()

  对多维数组进行比较其内容是否一致,不能用于一维数组,会编译不过滴~
6、toString(int[] a)
          返回指定数组内容的字符串表示形式。
7、copyOf(int[] original, int newLength)
          复制指定的数组,截取或用 0 填充(不足用0补齐),以使副本具有指定的长度。
8、copyOfRange(int[] original, int from, int to)  这里用到的方法
          将指定数组的指定范围复制到一个新数组。 
9、asList(array)
    利用Arrays.asList(array)将返回一个List,然而这个返回的List并不支持add和remove的操作。返回的List进行添加或删除时将会报 java.lang.UnsupportedOperationException 异常。
   原因:在Arrays.asList中,该方法接受一个变长参数,一般可看做数组参数,但是因为基本数据类型,如int[] 本身就是一个类型,所以data变量作为参数传递时,编译器认为只传了一个变量,这个变量的类型是int数组,所以size为1。       
   因为是arrays.aslist中,看代码可以看到这里返回的ArrayList不是原来的传统意义上的java.util.arraylist了,而是自己工具类的一个静态私有内部类,并没有提供add方法,要自己实现,所以这里是出错了,因此,除非确信array.aslist后长度不会增加,否则谨慎使用:List abc=Arrays.asList("a","b","c"),因为这样的长度是无法再add的了


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值