代码随想录算法训练营第三十九天-动态规划-198. 打家劫舍

  • 动规五部曲
    • dp[i]表示在下标为i的房间偷或不偷与前面所偷之和所能获得的最大价值
    • 递推公式:dp[i] = std::max(dp[i - 2] + nums[i], dp[i - 1])
    • 初始化:要给dp[0]dp[1]来给定初始值,因为递推公式有-1与-2。dp[0] = nums[0], dp[1] = std::max(nums[0], nums[1]);
      • 其它下标值,初始成任意值都可以,因为其值是由前面元素推导出来的
    • 遍历顺序:从2开始到最后一个房间的下标
    • 打印
cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        int dp[nums.size()];
        memset(dp, 0, sizeof(dp));
        if (nums.size() == 1) return nums.at(0);
        dp[0] = nums.at(0);
        dp[1] = std::max(dp[0], nums.at(1));
        for (int i = 2; i < nums.size(); i++) {
            dp[i] = std::max(dp[i - 1], dp[i - 2] + nums.at(i));
        }
        return dp[nums.size() - 1];
    }
};
相关推荐
cynicme3 小时前
力扣3318——计算子数组的 x-sum I(偷懒版)
java·算法·leetcode
ShineSpark5 小时前
Crashpad 在windows下编译和使用指南
c++·windows
Larry_Yanan6 小时前
QML学习笔记(五十)QML与C++交互:QML中单例C++对象
开发语言·c++·笔记·qt·学习·ui·交互
im_AMBER6 小时前
算法笔记 09
c语言·数据结构·c++·笔记·学习·算法·排序算法
凯芸呢6 小时前
Java中的数组(续)
java·开发语言·数据结构·算法·青少年编程·排序算法·idea
寂静山林6 小时前
UVa 1030 Image Is Everything
算法
AI柠檬7 小时前
几种排序算法的实现和性能比较
数据结构·算法·c#·排序算法
weixin_429630267 小时前
第6章 支持向量机
算法·机器学习·支持向量机
SweetCode7 小时前
C++ 实现大数加法
开发语言·c++·算法
王哈哈^_^7 小时前
【数据集】【YOLO】【目标检测】共享单车数据集,共享单车识别数据集 3596 张,YOLO自行车识别算法实战训推教程。
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计