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

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

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


原创内容 转载请注明出处

分享给朋友:

相关文章

70.爬楼梯|三步破解动态规划核心奥秘

70.爬楼梯|三步破解动态规划核心奥秘

题意新解:站在楼梯底仰望n级台阶,每步可选1或2阶,最终的路径组合犹如斐波那契数列般展开。比如到达第3阶的路径可由第1阶跨两步,或第2阶跨一步构成,这种递推规律揭示了两两相邻状态间的紧密关联。思路解析...

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

题目解读‌我们面对的是一个典型的图论问题:给定一个城市的连接矩阵,需要计算其中相互连通的城市群(省份)数量。这个问题可以抽象为无向图中的连通分量计算,每个城市代表图中的一个节点,城市之间的连接关系代表...

力扣933题:队列的妙用:如何高效统计最近请求

力扣933题:队列的妙用:如何高效统计最近请求

题目重解:我们需要设计一个能统计最近3000毫秒内请求次数的系统。每当新的请求到来时,它会带有时间戳t,我们需要返回过去3000毫秒内(包括当前)发生的请求总数。这就像是在时间轴上维护一个滑动窗口,只...

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

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

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

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

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

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

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

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

发表评论

访客

看不清,换一张

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