络腮胡菲菲 发表于 2024-10-16 16:54:31

LeetCode198:打家劫舍

题目链接:198. 打家劫舍 - 力扣(LeetCode)
代码如下
class Solution {
public:
    int rob(vector<int>& nums) {
      vector<int> dp(nums.size() + 1, 0);
      if(nums.size() == 1)return nums;
      if(nums.size() == 2)return max(nums, nums);
      dp = nums;
      dp = max(nums, nums);
      for(int i = 2; i < nums.size(); i++)
      {
            dp = max(dp, dp + nums);
      }
      return dp;
    }
}; 这个题目是一道经典的dp题目,起首我们先确定好dp的寄义,也就像题目所说的,dp是可以或许偷取的最大钱数,递推公式是dp = max(dp, dp + nums);这个是我们只看末了一个,也就是末了一个物品偷还是不偷,如果偷的话,那就是dp + nums, 不偷的话,那就是dp之前的房间,这个不一定是倒数第二个,也大概是倒数第三个,第四个.......初始化,dp毫无以为就是nums,dp也就是我要选前两个之家最大的数。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: LeetCode198:打家劫舍