leetcode_198_打家劫舍


思路 :首先定义一个数组对于dpi读作1->i能获取的最大利益,第i个房屋只有"偷"和不"偷"两种情况,分别进行讨论

"偷": 既然"偷"了 i那就肯定不能偷i-1 了,但是为了使"偷"的尽可能多除了必须不能"偷"的全要"偷",

所以得到第一个部分dpi=numsi+dpi-2;

不"偷" : 这就很明显了不"偷"那就是前i-1个的情况嘛dpi=dpi-1;

综上实现公式应为dpi=max(numsi+dpi-2,dpi-1);

实现代码如下

cpp 复制代码
int rob(vector<int>& nums) {
        int dp[105], size = nums.size();
        dp[0] = nums[0];
        if (size > 1)
            dp[1] = max(nums[0], nums[1]);
        for (int i = 2; i < size; i++) {
            dp[i] = max(nums[i] + dp[i - 2], dp[i - 1]);
        }
        return dp[size - 1];
    }
相关推荐
玖釉-22 分钟前
编辑距离(Edit Distance)——从字符串相似度到动态规划经典模型
算法·leetcode·动态规划
c2385635 分钟前
c/c++中的二叉树进阶
c语言·c++·算法
晚风吹红霞1 小时前
C++模板进阶:非类型参数、特化、分离编译与优缺点解析
开发语言·c++
吴可可1231 小时前
Win7下C#开发AutoCAD首选版本
算法
不会C语言的男孩1 小时前
C++ Primer 第8章:IO 库
开发语言·c++
Halo_tjn1 小时前
反射与设计模式2
java·开发语言·算法
磊 子1 小时前
C++仿函数以及STL内置仿函数
开发语言·c++
王璐WL1 小时前
【C++进阶】map/multimap 容器详解:从基础使用到底层实现与高频面试题
c++
_日拱一卒1 小时前
LeetCode:46全排列
算法·leetcode·职场和发展
剑挑星河月2 小时前
31.下一个排列
java·算法·leetcode