题解 | #打家劫舍(二)#

打家劫舍(二)

https://www.nowcoder.com/practice/a5c127769dd74a63ada7bff37d9c5815

#思路为分别删掉首尾元素算一次
class Solution:
    def rob(self , nums: List[int]) -> int:

        def deidai(n):
            if nums:
                dp[1] = nums[0]
                if n >1:
                    for i in range(2,n+1):
                        dp[i] = max(dp[i-1],dp[i-2]+nums[i-1])
        #第一次
        n = len(nums[:-1])
        dp = [0]*(n+1)
        deidai(n)
        ans = dp[n]
        #第二次
        nums.pop(0)
        n = len(nums)
        dp = [0]*(n+1)
        deidai(n)
        return max(ans,dp[n])

全部评论

相关推荐

07-02 13:52
门头沟学院 Java
点赞 评论 收藏
分享
宇算唯航:目测实缴资本不超100W的小公司
点赞 评论 收藏
分享
认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务