题解 | 打家劫舍(二)

打家劫舍(二)

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

import java.util.*;


public class Solution {

    public int rob (int[] nums) {
        int n=nums.length;
        return Math.max(method(nums,0,n-2),method(nums,1,n-1));
    }
    public int method (int[] nums,int start,int end) {
        int n=end-start+1;
        if (end==start)return nums[start];
        int []dp = new int [n + 1];
        //dp[i]为下标i为止的最大金额
        //dp[i]=max(nums[i]+dp[i-2],dp[i-1])
       
        dp[start] = nums[start];
        dp[start+1] = Math.max(nums[start], nums[start+1]);
        for (int i = 2; i <= end; i++) {
            dp[i] = Math.max(nums[i] + dp[i - 2], dp[i - 1]) ;
        }

        return dp[end];
    }
}

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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