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

打家劫舍(二)

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-03 14:32
点赞 评论 收藏
分享
点赞 评论 收藏
分享
06-18 13:28
已编辑
门头沟学院 Web前端
爱睡觉的冰箱哥:《给予你300的工资》,阴的没边了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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