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

来源:互联网 发布:紫萱和徐长卿知乎 编辑:程序博客网 时间:2024/06/05 20:45

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


0 0
原创粉丝点击