博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode刷题记录:构建最大数二叉树
阅读量:6464 次
发布时间:2019-06-23

本文共 797 字,大约阅读时间需要 2 分钟。

题目要求,

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

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函数调用次数过多,应该可以将结果放在一个变量中,提高执行效率。

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

39469-20170825142904777-1467390737.png

转载地址:http://yrhzo.baihongyu.com/

你可能感兴趣的文章
mysql+mysql_proxy+haproxy+memcache (mysql的读写分离)
查看>>
shell检测网站状态码和访问时间
查看>>
django与mysql交互
查看>>
Windows 搭建Hadoop 2.7.3开发环境
查看>>
python操作mysql数据库实现增删改查
查看>>
远程登录:Linux下 telnet 服务的安装与使用
查看>>
percona 5.7.11root初始密码设置
查看>>
ovirt官方安装文档 附录F
查看>>
Xtrabackup恢复mysql数据时候报错:Original data directory is not empty!
查看>>
Python的lambda表达式
查看>>
linux权限集中管理和行为日志审计
查看>>
存储过程基本语法
查看>>
JQuery与GridView控件结合示例
查看>>
安装IDSM-2系统映像到Catalyst IOS Software中
查看>>
composer常用包
查看>>
install_nginx_php
查看>>
Cognitive Security的异常检测技术
查看>>
常见扫描工具的介绍
查看>>
saltstack grains与pillar使用和订制
查看>>
虚拟机中安装vmware tools
查看>>