美文网首页
二叉树 Leetcode 654 最大二叉树

二叉树 Leetcode 654 最大二叉树

作者: 禾木清清 | 来源:发表于2019-07-14 17:27 被阅读0次

    题目

    给定一个不含重复元素的整数数组。一个以此数组构建的最大二叉树定义如下:

    二叉树的根是数组中的最大元素。
    左子树是通过数组中最大值左边部分构造出的最大二叉树。
    右子树是通过数组中最大值右边部分构造出的最大二叉树。
    通过给定的数组构建最大二叉树,并且输出这个树的根节点。

    Example 1:

    输入: [3,2,1,6,0,5]
    输入: 返回下面这棵树的根节点:

      6
    /   \
    

    3 5
    \ /
    2 0

    1
    注意:

    给定的数组的大小在 [1, 1000] 之间。

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/maximum-binary-tree
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路

    • 获取最大值的坐标作为根节点
    • 递归的将最大值左边的数值作为左子树
    • 右边的值作为右子树
    • 返回根节点

    代码

    # Definition for a binary tree node.
    # class TreeNode(object):
    #     def __init__(self, x):
    #         self.val = x
    #         self.left = None
    #         self.right = None
    
    class Solution(object):
        def constructMaximumBinaryTree(self, nums):
            """
            :type nums: List[int]
            :rtype: TreeNode
            """
            if not nums:
                return None
            
            max_val = max(nums)
            index = nums.index(max_val)
            
            root = TreeNode(max_val)
            
            root.left = self.constructMaximumBinaryTree(nums[:index])
            root.right = self.constructMaximumBinaryTree(nums[index+1:])
            return root
            
            
    

    相关文章

      网友评论

          本文标题:二叉树 Leetcode 654 最大二叉树

          本文链接:https://www.haomeiwen.com/subject/tclikctx.html