House Robber
2016-06-13 01:32
375 查看
You are a professional robber planning to rob houses along a street. Each house has a certain amount of money stashed, the only constraint stopping you from robbing each of them is that adjacent houses have security system connected and it
will automatically contact the police if two adjacent houses were broken into on the same night.
Given a list of non-negative integers representing the amount of money of each house, determine the maximum amount of money you can rob tonight without alerting the police.
Tags
DP
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
We can conclude the rule as:
f
= Math.max(f[n-1], f[n-2]+n);
will automatically contact the police if two adjacent houses were broken into on the same night.
Given a list of non-negative integers representing the amount of money of each house, determine the maximum amount of money you can rob tonight without alerting the police.
Tags
DP
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
We can conclude the rule as:
f
= Math.max(f[n-1], f[n-2]+n);
/** * @param {number[]} nums * @return {number} */ var rob = function (nums) { var len = nums.length; if (len === 0) { return 0; } var f = []; f[0] = nums[0]; f[1] = Math.max(nums[0], nums[1]); for (var i = 2; i < len; i++) { f[i] = Math.max(f[i - 2] + nums[i], f[i - 1]); } return f[len - 1]; };
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享