动态规划-House Robber
2018-04-29 20:20:56
House Robber问题是leetcode上经典的系列题,这里对其中的题目做一个讲解。
198. House Robber
问题描述:

问题求解:
本质上就是求解不连续取数的情况下能获得最大价值。可以使用动态规划来解决。
dp[i][0]:第i个数没有取能获得的最高价值
dp[i][1]:第i个数取能获得的最高价值
初始值:dp[-1][0] = 0,dp[-1][1] = -INF
递推关系式:dp[i][0] = max(dp[i - 1][0], dp[i - 1][1])
dp[i][1] = dp[i - 1] + nums[i]
public int rob(int[] nums) {
int[][] dp = new int[nums.length + 1][2];
dp[0][0] = 0;
dp[0][1] = Integer.MIN_VALUE;
for (int i = 1; i <= nums.length; i++) {
dp[i][0] = Math.max(dp[i - 1][1], dp[i - 1][0]);
dp[i][1] = dp[i - 1][0] + nums[i - 1];
}
return Math.max(dp[nums.length][0], dp[nums.length][1]);
}
可以对空间复杂度进行优化:
public int rob(int[] nums) {
int dp0 = 0;
int dp1 = Integer.MIN_VALUE;
for (int i = 1; i <= nums.length; i++) {
int tmp = dp0;
dp0 = Math.max(dp1, dp0);
dp1 = tmp + nums[i - 1];
}
return Math.max(dp0, dp1);
}
213. House Robber II
问题描述:

问题求解:
相较于上一题,本题出现了环路,显然的是如果状态是环路的话是无法运用dp的,因为dp是只考虑目前的情况,无后效性,而环路则意味着后面的状态会影响前面的状态,因此,我们要解决这个问题,首先要做的就是考虑使用某种手段来将环路打开。
对于rob问题,如果第i间屋子没有偷窃的话,那么第i + 1间屋子就可以任意取,也就是对于i + 1间屋子来说第i间屋子和不存在是一样的,因此我们可以在没有被偷窃的屋子上将环路断开。
下面考虑第n间屋子,他有两个状态,一是被偷窃,则第 n + 1间屋子必然没有被偷,则从 n + 1 处断开;二是没有被偷,则直接在 n 处断开。
public int rob(int[] nums) {
if (nums.length == 1) return nums[0];
return Math.max(helper(nums, 0, nums.length - 2), helper(nums, 1, nums.length - 1));
}
private int helper(int[] nums, int l, int r) {
int dp0 = 0;
int dp1 = Integer.MIN_VALUE;
for (int i = l; i <= r; i++) {
int tmp = dp0;
dp0 = Math.max(dp0, dp1);
dp1 = tmp + nums[i];
}
return Math.max(dp0, dp1);
}
337. House Robber III
问题描述:

问题求解:
本题是从数据结构的角度对原问题进行了扩展,将场景变到了二叉树上,限制条件依然是不能连续偷取。
从本质上来说,每个结点依然是两个状态,一是偷取了,二是没有偷取,因此,我们依然可以使用动态规划的方法自低向上的将每个结点的左右儿子结点的状态都得到后,再计算自己的值。
public int rob(TreeNode root) {
int[] res = helper(root);
return Math.max(res[0], res[1]);
}
private int[] helper(TreeNode root) {
if (root == null) return new int[2];
int[] res = new int[2];
int[] L = helper(root.left);
int[] R = helper(root.right);
res[0] = Math.max(L[0], L[1]) + Math.max(R[0], R[1]);
res[1] = L[0] + R[0] + root.val;
return res;
}
动态规划-House Robber的更多相关文章
- leetcode:House Robber(动态规划dp1)
You are a professional robber planning to rob houses along a street. Each house has a certain amount ...
- 一道简单的动态规划题目——House Robber
一.题目 House Robber(一道Leetcode上的关于动态规划的简单题目)具体描述如下: There is a professional robber planning to rob hou ...
- LeetCode之“动态规划”:House Robber && House Robber II
House Robber题目链接 House Robber II题目链接 1. House Robber 题目要求: You are a professional robber planning to ...
- leetcode-198-House Robber(动态规划)
题目描述: You are a professional robber planning to rob houses along a street. Each house has a certain ...
- Leetcode之动态规划(DP)专题-198. 打家劫舍(House Robber)
Leetcode之动态规划(DP)专题-198. 打家劫舍(House Robber) 你是一个专业的小偷,计划偷窃沿街的房屋.每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互 ...
- Leetcode 198 House Robber 动态规划
题意是强盗能隔个马抢马,看如何获得的价值最高 动态规划题需要考虑状态,阶段,还有状态转移,这个可以参考<动态规划经典教程>,网上有的下的,里面有大量的经典题目讲解 dp[i]表示到第i匹马 ...
- 动态规划 - 213. House Robber II
URL: https://leetcode.com/problems/house-robber-ii/ You are a professional robber planning to rob ho ...
- 动态规划 - 198. House Robber
URL : https://leetcode.com/problems/house-robber/ You are a professional robber planning to rob hous ...
- 213. House Robber II(动态规划)
You are a professional robber planning to rob houses along a street. Each house has a certain amount ...
随机推荐
- 最短路和次短路的条数(dijstra算法或spfa算法)POJ3463
http://poj.org/problem?id=3463 Sightseeing Time Limit: 2000MS Memory Limit: 65536K Total Submissio ...
- 310实验室 Linux 软件安装常见问题
电脑装好Linux系统后,系统默认安装软件不齐,需要自己根据自己的需要安装一些列工具软件,在linux系统中,用的最多的就是Synaptic Package Manager,什么是Synaptic?新 ...
- Linux系统下Redis缓存安装配置
Redis是一个高性能的key-value数据库,现时越来越多企业与应用使用Redis作为缓存服务器.楼主是一枚JAVA后端程序员,也算是半个运维工程师了.在Linux服务器上搭建Redis,怎么可以 ...
- sql 中如何将返回的记录某一条置顶
将table1中id 为2的记录置顶select * from table1order by case when id='2' then 0 else 1 end 例子:将已发布的置顶,status ...
- Codeforces Round #438 by Sberbank and Barcelona Bootcamp (Div. 1 + Div. 2 combined)
A. Bark to Unlock 题目链接:http://codeforces.com/contest/868/problem/A 题目意思:密码是两个字符组成的,现在你有n个由两个字符组成的字符串 ...
- Mybatis解决sql中like通配符模糊匹配 构造方法覆盖 mybits 增删改
<select id="getRecByNameWildcard" parameterType="Student" resultMap="res ...
- 锁、volatile、CAS 比较
一.锁的劣势 (1) 在JDK1.5之前都是使用synchronized关键字保证同步的,这种通过使用一致的锁定协议来协调对共享状态的访问,可以确保无论哪个线程持有守 护变量的锁,都采用独占的方式来访 ...
- Nginx 设置临时维护页面
Nginx 设置临时维护页面 http://www.myexception.cn/open-source/1753957.html http://blog.justwd.net/snippets/ng ...
- 2006 - MySQL server has gone away
mysql出现ERROR : (2006, 'MySQL server has gone away') 的问题意思就是指client和MySQL server之间的链接断开了. 造成这样的原因一般是s ...
- 实现linux下的ls
实现linux下的ls ls的使用 ls -a 列出文件下所有的文件,包括以"."开头的隐藏文件(linux下文件隐藏文件是以.开头的,如果存在..代表存在着父目录). ls -l ...