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

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

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


原创内容 转载请注明出处

分享给朋友:

相关文章

IOI 1994 洛谷1216:如何用O(1)空间解决数字三角形问题?附代码实现

IOI 1994 洛谷1216:如何用O(1)空间解决数字三角形问题?附代码实现

题目重解:数字三角形是一个经典的动态规划问题,给定一个由数字组成的三角形结构,从顶部出发,每次可以移动到下方相邻的数字,最终到达底部。我们需要找到一条路径,使得路径上经过的数字总和最大。这个问题可以很...

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

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

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

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

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

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

2024年GESP五级武器强化(洛谷B4071)解题代码C++版

2024年GESP五级武器强化(洛谷B4071)解题代码C++版

一、题目解读    2024年GESP(青少年软件编程能力等级考试)五级中的“武器强化”(洛谷平台题目编号B4071)是一道典型的算法优化问题。题目要求通过合理...

手搓顺序表类代码注释与详解:从零实现动态数组(新手教程)

一、简介和特点顺序表(Sequential List)是数据结构中基础的一种线性表,其特点是将数据元素存储在连续的内存空间中。通过数组实现,支持随机访问(即通过索引直接访问元素),适用于频繁随机读取的...

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

一、题目解读题目要求在一个n×m的网格中,从左上角到右下角选择一条路径,路径上的数字可重复取用,求取数之和的最大值。路径限制为仅能向右或向下移动。需注意路径的灵活性与重复取数的可能性,传统单向动态规划...

发表评论

访客

看不清,换一张

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