当前位置: 首页 > article >正文

代码随想录算法训练营第三十九天-动态规划-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开始到最后一个房间的下标
    • 打印
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];
    }
};
  • 汇总

http://www.kler.cn/a/524289.html

相关文章:

  • 2501,20个窗口常用操作
  • RocketMQ 中如何实现消息的可靠传递?
  • 元素的显示与隐藏
  • docker安装Redis:docker离线安装Redis、docker在线安装Redis、Redis镜像下载、Redis配置、Redis命令
  • 关于opencv环境搭建问题:由于找不到opencv_worldXXX.dll,无法执行代码,重新安装程序可能会解决此问题
  • 【C++】特殊类设计、单例模式与类型转换
  • 使用kitty terminal遇到的‘xterm-kitty‘: unknown terminal type.
  • 【Convex Optimization Stanford】Lec3 Function
  • 【C++题解】1056. 所有不超过1000的数中含有数字3的自然数
  • 2025年大年初一篇,C#调用GPU并行计算推荐
  • leetcode——二叉树的中序遍历(java)
  • 机器人基础深度学习基础
  • 记忆力训练day08
  • doris:HLL
  • 网络安全攻防实战:从基础防护到高级对抗
  • 园区管理系统如何赋能企业高效运营与资产全生命周期管理
  • 星际战争模拟系统:新月的编程之道
  • Javaweb入门-Maven项目学习(Day2)
  • 准备知识——旋转机械的频率和振动基础
  • Linux_线程互斥
  • Git 仓库命令
  • 58.界面参数传递给Command C#例子 WPF例子
  • WordPress Icegram Express插件Sql注入漏洞复现(CVE-2024-2876)(附脚本)
  • Java 大视界 -- Java 大数据在自动驾驶中的数据处理与决策支持(68)
  • 安卓逆向之脱壳-认识一下动态加载 双亲委派(一)
  • 设计模式的艺术-观察者模式