105. Construct Binary Tree from Preorder and Inorder Traversal.go

根据前序和中序遍历结果,构建二叉树
前序遍历的第一个节点,是数的根节点
从中序序列中找到根节点,则左边的都是左子树,右边的都是右子树
然后递归处理

type TreeNode struct {
    Val   int
    Left  *TreeNode
    Right *TreeNode
}

func buildTree(preorder []int, inorder []int) *TreeNode {
    if len(preorder) == 0 {
        return nil
    }
    res := &TreeNode{
        Val: preorder[0],
    }
    if len(preorder) == 1 {
        return res
    }
    idx := func(val int, nums []int) int {
        for i, v := range nums {
            if v == val {
                return i
            }
        }
        return -1
    }(res.Val, inorder)
    if idx == -1 {
        return nil
    }
    res.Left = buildTree(preorder[1:idx+1], inorder[:idx])
    res.Right = buildTree(preorder[idx+1:], inorder[idx+1:])
    return res
}

你可能感兴趣的:(105. Construct Binary Tree from Preorder and Inorder Traversal.go)