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

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

5个月前 (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;                    // 返回计算的最高收益
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

NOIP2005 普及组 洛谷P1408 背包问题的空间优化技巧与实战应用

NOIP2005 普及组 洛谷P1408 背包问题的空间优化技巧与实战应用

题目重解想象你是一名药师,有t分钟在山上采集m种草药。每种草药需要time分钟采集,价值为num。这就像考试时分配时间做题,要选择收益最大的题目组合。题目要求计算在规定时间内能获得的最大草药价值。解题...

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

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

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

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

一、题目解读小杨买饮料是GESP 2023年六级认证考试中的一道经典动态规划题目,考察学生对背包问题的理解和应用能力。题目描述小杨需要购买n种饮料,每种饮料有特定的体积w和价格v,他要在不超过容量l的...

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

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

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

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

一、题目解读LeetCode 120题“三角形最小路径和”要求给定一个由数字组成的三角形,从顶部开始向下移动,每次可向左或向右移动一格,计算从顶至底的最小路径和。三角形以二维向量形式给出,每层元素数量...

力扣931题最小下降路径和解析 动态规划解法 LeetCode解题技巧

力扣931题最小下降路径和解析 动态规划解法 LeetCode解题技巧

一、题目解读力扣931题「Minimum Falling Path Sum」(最小下降路径和)要求在一个n x n的整数矩阵中,计算从顶部到底部的最小路径和。路径只能从每个位置向下或对角线移动(即向下...

发表评论

访客

看不清,换一张

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