0
点赞
收藏
分享

微信扫一扫

学习笔记--动态规划-打家劫舍(java)

微言记 2022-03-18 阅读 73
java学习

打家劫舍
        你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,
        如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。    
        给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。
        示例 1:        
        输入:[1,2,3,1]
        输出:4
        解释:偷窃 1 号房屋 (金额 = 1) ,然后偷窃 3 号房屋 (金额 = 3)。
             偷窃到的最高金额 = 1 + 3 = 4 。
        
        示例 2:        
        输入:[2,7,9,3,1]
        输出:12
        解释:偷窃 1 号房屋 (金额 = 2), 偷窃 3 号房屋 (金额 = 9),接着偷窃 5 号房屋 (金额 = 1)。
             偷窃到的最高金额 = 2 + 9 + 1 = 12 。

偷窃第i间房屋,那么就不能偷窃第 i−1 间房屋,偷窃总金额为前 i−2 间房屋的最高总金额与第 i间房屋的金额之和。

不偷窃第i间房屋,偷窃总金额为前i−1 间房屋的最高总金额。

dp[i]=max(dp[i−2]+nums[i],dp[i−1])

public static int rob(int[] nums) {
	     int []dp=new int[nums.length];	
	     dp[0]=nums[0];
	     
		 for(int i=1;i<nums.length;i++) {
			 if(i==1) {
				 dp[1]=Math.max(nums[0], nums[1]);
			 }else {
				 dp[i]=Math.max(nums[i]+dp[i-2], dp[i-1]);
			 }
		 }		 
		 return dp[nums.length-1];
	 }
举报

相关推荐

0 条评论