您的位置:首页 > 文旅 > 美景 > 网页视频下载不了怎么办_南京各区房价一览表_站长素材音效网_最稳定的灰色词排名

网页视频下载不了怎么办_南京各区房价一览表_站长素材音效网_最稳定的灰色词排名

2024/12/22 18:16:27 来源:https://blog.csdn.net/Ricky_youngone/article/details/142945191  浏览:    关键词:网页视频下载不了怎么办_南京各区房价一览表_站长素材音效网_最稳定的灰色词排名
网页视频下载不了怎么办_南京各区房价一览表_站长素材音效网_最稳定的灰色词排名

题目链接:198. 打家劫舍 - 力扣(LeetCode)

代码如下

class Solution {
public:int rob(vector<int>& nums) {vector<int> dp(nums.size() + 1, 0);if(nums.size() == 1)  return nums[0];if(nums.size() == 2)  return max(nums[0], nums[1]);dp[0] = nums[0];dp[1] = max(nums[0], nums[1]);for(int i = 2; i < nums.size(); i++){dp[i] = max(dp[i - 1], dp[i - 2] + nums[i]);}return dp[nums.size() - 1];}
};

这个题目是一道经典的dp问题,首先我们先确定好dp[j]的含义,也就像题目所说的,dp是能够偷取的最大钱数,递推公式是dp[i] = max(dp[i - 1], dp[i - 2] + nums[i]);这个是我们只看最后一个,也就是最后一个物品偷还是不偷,如果偷的话,那就是dp[i - 2] + nums[i], 不偷的话,那就是dp[i - 1]之前的房间,这个不一定是倒数第二个,也可能是倒数第三个,第四个.......初始化,dp[0]毫无以为就是nums[0],dp[1]也就是我要选前两个之家最大的数。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com