106. 从中序与后序遍历序列构造二叉树(递归版)

本文介绍如何根据二叉树的中序与后序遍历序列来重建该二叉树,通过递归方式实现,并附带示例代码。
/**
 * 106. 从中序与后序遍历序列构造二叉树
 * @author wsq
 * @date 2020/09/25
	根据一棵树的中序遍历与后序遍历构造二叉树。
	注意:
	你可以假设树中没有重复的元素。

	例如,给出
	中序遍历 inorder = [9,3,15,20,7]
	后序遍历 postorder = [9,15,7,20,3]
	
	返回如下的二叉树:
	    3
	   / \
	  9  20
	    /  \
	   15   7
	
	链接:https://leetcode-cn.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal
 */
package notsubmit;

public class MidPosBuildTree {
	/**
	 *	根据后序遍历与中序遍历的特点
	 *	采用递归的方式构建二叉树
	 *	以后会尝试使用迭代的方式实现树的构建
	 * @param inorder
	 * @param postorder
	 * @return
	 */
    public TreeNode buildTree(int[] inorder, int[] postorder) {
    	int inLen = inorder.length;
    	int posLen = postorder.length;
    	if(inLen == 0 || posLen == 0 || inLen != posLen) {
    		return null;
    	}
    	// 递归建树
    	TreeNode root = reBuildTree(inorder, postorder, 0, inLen - 1, 0, posLen - 1);
    	return root;
    }
    
    private TreeNode reBuildTree(int[] inorder, int[] postorder, 
    							 int inStart, int inEnd, 
    							 int postStart, int postEnd) {
		// TODO Auto-generated method stub
    	if(inStart > inEnd || postStart > postEnd) {
    		return null;
    	}
    	int rootVal = postorder[postEnd];
    	TreeNode rootNode = new TreeNode(postorder[postEnd]);
    	
    	if(postStart == postEnd) {
    		return rootNode;
    	}
    	
    	int inPos = findInorder(inorder, inStart, inEnd, rootVal);
    	int leftTreeNum = inPos - inStart;

    	rootNode.left = reBuildTree(inorder, postorder, inStart, inPos - 1, postStart, postStart + leftTreeNum - 1);
    	rootNode.right = reBuildTree(inorder, postorder, inPos + 1, inEnd, postStart + leftTreeNum, postEnd - 1);
		return rootNode;
	}

	private int findInorder(int[] inorder, int inStart, int inEnd, int rootVal) {
		// TODO Auto-generated method stub
		for(int i = inStart; i <= inEnd; ++i) {
			if(inorder[i] == rootVal) {
				return i;
			}
		}
		return -1;
	}
	
	public static void main(String[] args) {
		int[] inorder = {2, 1};
		int[] postorder = {2, 1};
		MidPosBuildTree bt = new MidPosBuildTree();
		TreeNode head = bt.buildTree(inorder, postorder);
	}

}

编号 文件名称 cwts-specs-001 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:名语术语 cwts-specs-002 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:概述 cwts-specs-003 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:物理信道和传输信道到物理信道的映射 cwts-specs-004 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:信道编码与复用 cwts-specs-005 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:扩频与调制 cwts-specs-006 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:物理层过程 cwts-specs-007 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:物理层测量 cwts-specs-008 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:物理层向上层提供的服务 cwts-specs-009 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:MAC协议 cwts-specs-010 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:RLC协议 cwts-specs-011 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:PDCP协议 cwts-specs-012 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:BMC协议 cwts-specs-013 IMT-DS FDD(WCDMA)系统无线接口层3技术规范:RRC协议 cwts-specs-014 IMT-DS FDD(WCDMA)系统Iu接口技术规范:概述 cwts-specs-015 IMT-DS FDD(WCDMA)系统Iu接口技术规范:层1技术要求 cwts-specs-016 IMT-DS FDD(WCDMA)系统Iu接口技术规范:信令传输 cwts-specs-017 IMT-DS FDD(WCDMA)系统Iu接口技术规范:RANAP信令 cwts-specs-018 IMT-DS FDD(WCDMA)系统Iu接口技术规范:数据传输和传输信令 cwts-specs-019 IMT-DS FDD(WCDMA)系统Iu接口技术规范:用户平面协议 cwts-specs-020 IMT-DS FDD(WCDMA)系统Iub接口技术规范:概述 cwts-specs-021 IMT-DS FDD(WCDMA)系统Iub接口技术规范:层1技术要求 cwts-specs-022 IMT-DS FDD(WCDMA)系统Iub接口技术规范:信令传输 cwts-specs-023 IMT-DS FDD(WCDMA)系统Iub接口技术规范:NBAP信令 cwts-specs-024 IMT-DS FDD(WCDMA)系统Iub接口技术规范:用于CCH数据流的数据传输和传输信令 cwts-specs-025 IMT-DS FDD(WCDMA)系统Iub接口技术规范:用于CCH数据流的用户平面协议 cwts-specs-026 IMT-DS FDD(WCDMA)系统Iur接口技术规范:概述 cwts-specs-027 IMT-DS FDD(WCDMA)系统Iur接口技术规范:层1技术要求 cwts-specs-028 IMT-DS FDD(WCDMA)系统Iur接口技术规范:信令传输 cwts-specs-029 IMT-DS FDD(WCDMA)系统Iur接口技术规范:RNSAP信令 cwts-specs-030 IMT-DS FDD(WCDMA)系统Iur接口技术规范:用于CCH数据流的数据传输和传输信令 cwts-specs-031 IMT-DS FDD(WCDMA)系统Iur接口技术规范:用于CCH数据流的用户平面协议 cwts-specs-032 IMT-DS FDD(WCDMA)系统Iub/Iur接口技术规范:用于DCH数据流的数据传输和传输信令 cwts-specs-033 IMT-DS FDD(WCDMA)系统Iub/Iur接口技术规范:用于DCH数据流的用户平面协议 cwts-specs-034 TD-SCDMA系统无线接口物理层技术规范 cwts-specs-035 TD-SCDMA系统无线接口层2技术规范 cwts-specs-036 TD-SCDMA系统无线接口层3-RRC技术规范 cwts-specs-037 TD-SCDMA系统Iu接口技术规范 cwts-specs-038 TD-SCDMA系统Iub接口技术规范 cwts-specs-039 TD-SCDMA系统Iur接口技术规范 cwts-specs-040 TD-SCDMA系统基站设备无线收发特性技术规范 cwts-specs-041 TD-SCDMA系统用户终端设备无线收发特性技术规范 CWTS发布的研究报告列表 cwts-reports-001 IMT-DS FDD(WCDMA)系统连接模式下的层间过程(25.303)标准研究报告 cwts-reports-002 IMT-DS FDD(WCDMA)系统空闲模式下UE的流程和连接模式下小区重选流程(25.304)标准研究报告 cwts-reports-003 IMT-DS FDD(WCDMA)系统无线资源管理RRM研究报告 cwts-reports-004 IMT-DS FDD(WCDMA)系统无线资源管理RRM研究报告 cwts-reports-005 IMT-DS FDD(WCDMA)系统UE无线接入能力研究报告
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值