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];
    }
相关推荐
Lsk_Smion16 分钟前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode
知无不研24 分钟前
对套接字的深入理解
linux·服务器·网络·c++·socket·网络套接字
jidaowansui1 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·算法
hai3152475432 小时前
FlashAttention C语言(C++)实现(展示版)
c语言·开发语言·c++·人工智能·算法
林爷万福2 小时前
光谱数据预处理:基线校正、平滑去噪实战
人工智能·算法
8Qi82 小时前
LeetCode 1049:最后一块石头的重量 II —— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
wuminyu2 小时前
Java锁机制之Java对象重量级锁源码剖析
java·linux·c语言·jvm·c++
wubba lubba dub dub7502 小时前
第四十九周学习周报
人工智能·算法·机器学习
Java_2017_csdn3 小时前
ComplexKeysShardingAlgorithm 小结
java·大数据·算法
海梨花3 小时前
快手面试高频算法题
java·算法·面试