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

打家劫舍(二)

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-16 12:23
点赞 评论 收藏
分享
06-15 20:57
已编辑
门头沟学院 Java
CARLJOSEPH...:年轻人有傲气很正常,但是建议工作前洗净傲气。 说实在的,什么奖学金什么奖项的都很一般。尊重你的老师,在有时间的时候去上课,真遇到走不开的事,请态度端正地向你的老师说明情况,请求请假。我相信任何一个有师德的老师都会允许的(我的老师就是这样)。
点赞 评论 收藏
分享
07-18 14:34
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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