代码随想录算法训练营第三十九天-动态规划-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];
    }
};
相关推荐
Stack Overflow?Tan9044 分钟前
c++实现在同一台主机两个程序实现实时通信
开发语言·c++
@@永恒1 小时前
map&set
c++
北顾南栀倾寒2 小时前
[算法笔记]cin和getline的并用、如何区分两个数据对、C++中std::tuple类
笔记·算法
小鹏编程2 小时前
【C++教程】C++中的基本数据类型
开发语言·c++·教程·少儿编程
熊峰峰2 小时前
C++第十节:map和set的介绍与使用
开发语言·c++
Antonio9152 小时前
【网络编程】事件选择模型
网络·c++
程序员Linc3 小时前
用OpenCV写个视频播放器可还行?(C++版)
c++·opencv·音视频·opencv 4.11
一只大侠3 小时前
牛客周赛A:84:JAVA
算法
决斗小饼干3 小时前
并发编程知识总结
c++
豆豆酱3 小时前
Informer方法论详解
算法