zoukankan      html  css  js  c++  java
  • LintCode2016年8月8日算法比赛----中序遍历和后序遍历构造二叉树

    中序遍历和后序遍历构造二叉树

    题目描述

    根据中序遍历和后序遍历构造二叉树

     注意事项
    
    你可以假设树中不存在相同数值的节点
    
    样例

    给出树的中序遍历: [1,2,3] 和后序遍历: [1,3,2]

    返回如下的树:

      2
     /  
    1    3
    
    算法分析:

    给定同一课二叉树的中序和后序遍历数组,那么后序遍历数组的最后一个元素就是根节点的元素。在中序遍历数组中找到这个元素的index(能够找到这个唯一的index,依据就是树中不存在相同数值的节点),那么这个index就把中序遍历的数组分割成了左子树和右子树的数组两个部分。则中序遍历数组中,0index-1的数据为左子树的数据,index+1length-1的数据为右子树的数据;后序遍历数组中,0index-1的数据为左子树的数据,indexlength-2的数据为右子树的数据。(后序遍历的数组中的下标为length-1的数据为根节点数据)

    Java算法实现:

    /**
     * Definition of TreeNode:
     * public class TreeNode {
     *     public int val;
     *     public TreeNode left, right;
     *     public TreeNode(int val) {
     *         this.val = val;
     *         this.left = this.right = null;
     *     }
     * }
     */
     
     
    public class Solution {
        /**
         *@param inorder : A list of integers that inorder traversal of a tree
         *@param postorder : A list of integers that postorder traversal of a tree
         *@return : Root of a tree
         */
       	public static  TreeNode buildTree(int[] inorder, int[] postorder) {
            // write your code here
            TreeNode root=makeTree(inorder, 0, inorder.length, postorder, 0, postorder.length);
    		
    		return root;
        }
        
        
        public static TreeNode makeTree(int[] inorder,int startIn,int lenIn,int[] postorder,int startPos,int lenPos){
    		if(lenIn<1){
    			return null;
    		}
    		TreeNode root;
    		int rootVal=postorder[startPos+lenPos-1];//postorder中的最后一个元素就是当前处理的数据段的根节点
    		root=new TreeNode(rootVal);
    		int offset;
    		boolean isFound=false;
    		for(offset=0;offset<lenIn;offset++){
    			
    			if(inorder[startIn+offset]==rootVal){
    				isFound=true;//标记确实找到了根节点
    				break;
    			}
    		}
    		if(!isFound)//如果不存在相等的情况,赢跳出该函数
    			return root;
    		//找到了根节点在 inorder 中的下标,将 inorder 分割为两部分:(1)--startIn~(startIn+offset-1)为左子树的数据
    		//(2)--(startIn+offset+1)~(startIn+lenIn-1)为右子树的数据
    		//同样,postorder中,也将数据分割为两部分:(1)--startPos~(startPos+offset-1)为左子树的数据
    		//(2)--(startPos+offset)~(startPos+lenPos-2)右子树的数据
    		root.left=makeTree(inorder, startIn, offset, postorder, startPos, offset);
    		root.right=makeTree(inorder, startIn+offset+1, lenIn-offset-1, postorder, startPos+offset, lenPos-offset-1);
    		return root;
    	}
    }
  • 相关阅读:
    MySQL技术内幕(第5版)
    Creo Parametric 4.0基础、进阶、高手一本通
    PostgreSQL 9.0性能调校
    Python程序设计案例课堂
    Creo2.0完全学习手册
    Excel会计电算化与应用(第3版)
    JPEG与RAW的较量 数码影像拍摄与后期全流程详解
    [Objective-c 基础
    [Objective-c 基础
    iOS开发网络篇—GET请求和POST请求(转)
  • 原文地址:https://www.cnblogs.com/dongling/p/5795978.html
Copyright © 2011-2022 走看看