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];
    }
相关推荐
Justice Young3 分钟前
算法分析与设计实验:贪心法求解0/1背包问题的局限性
算法
黎阳之光8 分钟前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
小许同学记录成长22 分钟前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
Swift社区22 分钟前
OpenHarmony鸿蒙PC平台移植 gifsicle:CC++ 三方库适配实践(Lycium tpc_c_cplusplus)
c语言·c++·harmonyos
凯瑟琳.奥古斯特25 分钟前
力扣1001网格照明解法
算法·leetcode·职场和发展
fengenrong27 分钟前
20260601
算法·深度优先·图论
晚笙coding30 分钟前
从“看起来像双指针”到真正的动态规划 —— 最长公共子序列
算法·动态规划
basketball61640 分钟前
C++进阶:1. 引用折叠规则
java·开发语言·c++
05候补工程师43 分钟前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
酬勤-人间道1 小时前
VTK 与 Cesium-native 结合实践:小场景三维编辑 + 数字地球精准贴合
c++·qt·vtk·遥感·岩土·cesium-native