LeetCode:83.打家劫舍

目录

1.打家劫舍


1.打家劫舍

我们设dp[i]表示偷到第i间屋子时的最高金额,可以分为以下两种情况:

  1. 第i间屋子不偷,所以i-1间屋子可以投偷,dp[i] = dp[i - 1]
  2. 第i间屋子偷,由于不能偷相邻的屋子,所以i - 1不能偷,但是i - 2可以,dp[i] = dp[i - 2] + nums[i]

综上所述:dp[i] = max(dp[i - 2] + nums[i], dp[i - 1])

我们要注意初始值,dp[0]没有房子偷,所以dp[0] = 0, dp[1] 只能偷第一间,dp[1] = nums[0]

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        int n = nums.size();
        vector<int> dp(n + 1);
        dp[0] = 0, dp[1] = nums[0];
        for(int i = 2; i <= n; i++)
            dp[i] = max(dp[i - 2] + nums[i - 1], dp[i - 1]);
        return dp[n];
    }
};
相关推荐
LXS_3572 分钟前
STL - 函数对象
开发语言·c++·算法
aini_lovee6 分钟前
基于粒子群算法(PSO)优化BP神经网络权值与阈值的实现
神经网络·算法
老鼠只爱大米14 分钟前
LeetCode经典算法面试题 #230:二叉搜索树中第K小的元素(递归法、迭代法、Morris等多种实现方案详细解析)
算法·leetcode·二叉搜索树·二叉树遍历·第k小的元素·morris遍历
星期五不见面17 分钟前
嵌入式学习!(一)C++学习-leetcode(21)-26/1/29
学习·算法·leetcode
2501_9413220322 分钟前
通信设备零部件识别与检测基于改进YOLOv8-HAFB-2算法实现
算法·yolo
modelmd30 分钟前
【递归算法】汉诺塔
python·算法
2401_8384725136 分钟前
C++中的装饰器模式实战
开发语言·c++·算法
白中白1213843 分钟前
算法题-06
算法
珍珠是蚌的眼泪1 小时前
LeetCode_二叉树1
leetcode·二叉树·层序遍历·前序遍历·中序遍历·后续遍历
爱学习的阿磊1 小时前
C++与Qt图形开发
开发语言·c++·算法