LintCode 前序遍歷和中序遍歷樹(shù)構(gòu)造二叉樹(shù)

題目

根據(jù)前序遍歷和中序遍歷樹(shù)構(gòu)造二叉樹(shù).

注意事項(xiàng)

你可以假設(shè)樹(shù)中不存在相同數(shù)值的節(jié)點(diǎn)

樣例
給出中序遍歷:[1,2,3]和前序遍歷:[2,1,3]. 返回如下的樹(shù):

2
/
1 3

代碼

/**
 * 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 preorder : A list of integers that preorder traversal of a tree
     *@param inorder : A list of integers that inorder traversal of a tree
     *@return : Root of a tree
     */
    private int findPosition(int[] arr, int start, int end, int key) {
        int i;
        for (i = start; i <= end; i++) {
            if (arr[i] == key) {
                return i;
            }
        }
        return -1;
    }

    private TreeNode myBuildTree(int[] inorder, int instart, int inend,
            int[] preorder, int prestart, int preend) {
        if (instart > inend) {
            return null;
        }

        TreeNode root = new TreeNode(preorder[prestart]);
        int position = findPosition(inorder, instart, inend, preorder[prestart]);

        root.left = myBuildTree(inorder, instart, position - 1,
                preorder, prestart + 1, prestart + position - instart);
        root.right = myBuildTree(inorder, position + 1, inend,
                preorder, position - inend + preend + 1, preend);
        return root;
    }

    public TreeNode buildTree(int[] preorder, int[] inorder) {
        if (inorder.length != preorder.length) {
            return null;
        }
        return myBuildTree(inorder, 0, inorder.length - 1, preorder, 0, preorder.length - 1);
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 樹(shù)的概述 樹(shù)是一種非常常用的數(shù)據(jù)結(jié)構(gòu),樹(shù)與前面介紹的線性表,棧,隊(duì)列等線性結(jié)構(gòu)不同,樹(shù)是一種非線性結(jié)構(gòu) 1.樹(shù)的定...
    Jack921閱讀 4,754評(píng)論 1 31
  • 今天看了一篇文章,說(shuō)是女主在婚前買戒指的時(shí)候,挑了一個(gè)最便宜的! 因?yàn)閻?ài)對(duì)方,所以在經(jīng)濟(jì)不寬裕的情況下,盡量為他省...
    惡魔的新娘閱讀 731評(píng)論 0 1
  • 微小品_風(fēng)鈴 2016.01.08 “叮鈴鈴,叮鈴鈴……”風(fēng)鈴唱著歡快的歌。 這是一只很普通的風(fēng)鈴,簡(jiǎn)單的造型,淡...
    老貓solo閱讀 676評(píng)論 0 1
  • 一、梯瑪膏藥的效果及主治范圍是哪些? 湘西土家梯瑪黑膏藥是專治頸、肩、腰、腿關(guān)節(jié)疼痛的百年老字號(hào)膏藥。主治頸椎病,...
    陶哥1986閱讀 10,848評(píng)論 0 2

友情鏈接更多精彩內(nèi)容