当前位置:首页 > 力扣 > 力扣198.打家劫舍|动态规划解法中的特殊边界处理

力扣198.打家劫舍|动态规划解法中的特殊边界处理

4个月前 (05-14)

力扣198.打家劫舍|动态规划解法中的特殊边界处理 力扣 动态规划 C++ 算法 第1张

题意解析:

在排列成直线的房屋群中,每个房屋藏有价值不同的财物。小偷不能连续抢劫相邻的两间房屋,否则会触发警报。我们需要设计一套抢劫策略,使得在不触发警报的前提下,能够获取的最大财物总和。这个问题本质上是在不连续区间内寻找价值最大化的数学组合问题。


思路解析:

采用‌动态规划+特殊边界处理‌策略:

1‌.极端情况处理‌:

    房屋数量≤3时直接比较所有可能的组合结果

    当只有3间房时,最大收益为“首尾之和”或“中间值”的较大者

2.‌DP数组构建‌:

    dp[i]存储前i间房的理论最大收益

    初始化前三个状态:dp[0]存首房价值,dp[1]取前两房较大值,dp[2]对比三种可能性

3‌.递推策略创新‌:

    从第4间房开始,递推式dp[i] = max(dp[i-2]+nums[i], dp[i-3]+nums[i-1])

    不仅考虑前两间的状态,还引入前三间状态的对比,有效避免局部最优陷阱

‌4.最大值维护‌:

    每次计算新的dp[i]后更新全局最大值maxdp

    最终返回遍历过程中出现的最大收益值57


代码注释:

class Solution {
public:
    int rob(vector<int>& nums) {
        // 处理房屋数量少的特殊情况
        if(nums.size()==1) return nums[0];             // 仅一间房直接返回
        if(nums.size()==2) return max(nums[0],nums[1]);// 两间房取较大值
        if(nums.size()==3)                             // 三间房特殊处理
            return max(nums[0]+nums[2],nums[1]);       // 比较首尾之和与中间值

        int dp[100];                                   // DP数组预留足够空间
        dp[0]=nums[0];                                 // 首间房必选
        dp[1]=max(nums[0],nums[1]);                    // 前两间取较大者
        dp[2]=max(nums[0]+nums[2],nums[1]);            // 前三间最优解计算
        int maxdp=dp[2];                               // 初始化当前最大值

        // 动态规划递推过程
        for(int i=3;i<nums.size();i++) {
            // 核心状态转移方程:比较两种跨步方案
            dp[i]=max(dp[i-2]+nums[i],   // 方案一:间隔两间抢当前房
                      dp[i-3]+nums[i-1]);// 方案二:间隔三间抢前一房
            maxdp=max(dp[i],maxdp);      // 动态维护全局最大值
        }
        return maxdp;                    // 返回计算的最高收益
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

题目解读给定一个整数数组,我们需要找到一个中心索引,使得该索引左侧所有元素的和等于右侧所有元素的和。如果不存在这样的索引,则返回-1。中心索引的定义不包含在左右两侧的和计算中。这个问题考察对数组遍历和...

力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界

力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界

题目解读‌:在二叉搜索树的世界里,每个节点都默默记录着自己的数值。现在我们需要找出这些数值中出现频率最高的那些数字,也就是所谓的"众数"。有趣的是,二叉搜索树本身具有左小右大的特性...

力扣540题:线性扫描法如何高效定位唯一数

力扣540题:线性扫描法如何高效定位唯一数

题目重解一个严格递增的有序数组中,除某个元素外,其余每个元素均出现两次。这个看似简单的条件背后隐藏着巧妙的规律——单一元素会打破数组的"成对对称性"。题目要求以O(log n)时间...

牛客12576题解题全解析:动态规划+质因数分解实现跳跃问题最优解

牛客12576题解题全解析:动态规划+质因数分解实现跳跃问题最优解

一、题目解读牛客12576题是一道经典的算法题,要求给定起点N和终点M,求解从N到M的最少跳跃次数。题目考察的核心在于路径优化与动态规划思想,需结合数论中的质因数分解技巧,通过合理设计算法降低时间复杂...

NOIP 2008火柴棒等式题解(C++代码实现)  动态规划与枚举算法详解

NOIP 2008火柴棒等式题解(C++代码实现) 动态规划与枚举算法详解

一、题目解读火柴棒等式问题(NOIP 2008,洛谷P1149)要求使用给定数量的火柴棒,构造形如 A + B = C 的等式,其中A、B、C均为整数,且火柴棒总数恰好等于输入值。需统计符合条件的等式...

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

一、题目解读2024年蓝桥杯省B组“传送阵”题目要求处理一个包含n个节点的图,节点间存在单向传输关系。每个节点i可传送至a[i]指定的节点,形成可能存在的环结构。题目需求解从任意节点出发能到达的最长路...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。