有不含有重复数字的数组构造二叉树_Leetcode刷题记录:构建最大数二叉树

题目要求,题目地址

给定一个不含重复数字的数组,最大二叉树构建规则如下:

1、根是数组中最大的数字

2、左边的子树是最大数字左边的内容

3、右边的子树是最大数字右边的内容

答案

class Solution(object):

def constructMaximumBinaryTree(self, nums):

"""

:type nums: List[int]

:rtype: TreeNode

"""

#print(max(nums))

#print(nums.index(max(nums)))

#print(nums)

if len(nums) == 0:

return None

t = TreeNode(max(nums))

if len(nums) > 1:

t.left = self.constructMaximumBinaryTree(nums[:nums.index(max(nums))])

t.right = self.constructMaximumBinaryTree(nums[nums.index(max(nums)) + 1 :])

else:

t.left = None

t.right = None

return t

优化思路

提交后这个答案只打败了17%的对手,分析一下感觉是因为index、len函数调用次数过多,应该可以将结果放在一个变量中,提高执行效率。

本文为作者原创,如果您觉得本文对您有帮助,请随意打赏,您的支持将鼓励我继续创作。

你可能感兴趣的:(有不含有重复数字的数组构造二叉树_Leetcode刷题记录:构建最大数二叉树)