leetcode:House Robber II

相比于上一问,这道题加了一个限制条件是房子是一个环,即nums[0]和nums[n-1]是相邻的,两个房间不能同时抢劫。   那么实际上这个环可以分解为0到length-2以及1到length-1这两个区间,区间内的求解和上一问一致,求最大值即可。(即选不选择nums[0]的两种可能性比较一下,其他的思想和上一问一致)


public class Solution {
    public int rob(int[] nums) {
        if( nums.length == 0 )
        {
            return 0;
        }
        if( nums.length== 1 )
        {
            return nums[0];
        }
        return Math.max( fun(nums,0,nums.length-2),fun(nums,1,nums.length-1) );
    }
    
    int fun(int[] nums,int st,int ed)
    {
        // int[] rt = new int[nums.length];
        if( st==ed )
        {
            return nums[st];
        }
        int d1=nums[st],d2=Math.max(nums[st],nums[st+1]);
        for( int i=st+2;i<=ed;i++ )
        {
            int temp = d2;
            d2 = Math.max( d2,d1+nums[i] );
            d1 = temp;
        }
        return d2;
    }
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值