每日一题(力扣198):打家劫舍--dp

考虑到达第n家房屋时,偷偷这家的钱 :1 如果不偷,那么当前最大值是前n-1家房屋中可以偷的最多的钱 2 如果偷 ,那就是这家的钱 +前n-2家房屋可以偷的最多的钱。(从数组的结果值考虑,不然容易绕进去)。

cpp 复制代码
class Solution {
    public:
    int rob(vector<int>& nums) {
        int n=nums.size();
        if(n==1)return nums[0];
        vector<int> dp(n,0);
        dp[0]=nums[0];
        dp[1]=max(nums[0],nums[1]);
        for(int i=2;i<n;i++){
            dp[i]=max(dp[i-2]+nums[i],dp[i-1]);
        }
        int res=max(dp[n-1],dp[n-2]);
        return res;
    }
};
相关推荐
寒小松5 分钟前
Problem E: List练习
java·数据结构·list
↣life♚31 分钟前
从SAM看交互式分割与可提示分割的区别与联系:Interactive Segmentation & Promptable Segmentation
人工智能·深度学习·算法·sam·分割·交互式分割
zqh1767364646937 分钟前
2025年阿里云ACP人工智能高级工程师认证模拟试题(附答案解析)
人工智能·算法·阿里云·人工智能工程师·阿里云acp·阿里云认证·acp人工智能
fie88891 小时前
用模型预测控制算法实现对电机位置控制仿真
算法
Kent_J_Truman1 小时前
【交互 / 差分约束】
算法
清幽竹客1 小时前
redis数据结构-02(INCR、DECR、APPEND)
数据结构·redis
Akiiiira1 小时前
【数据结构】线性表
数据结构
ghie90901 小时前
x-IMU matlab zupt惯性室内定位算法
人工智能·算法·matlab
Magnum Lehar1 小时前
3d游戏引擎的Utilities模块实现
c++·算法·游戏引擎
小狗祈祷诗1 小时前
day20-线性表(链表II)
c语言·数据结构·链表