LeetCode198:打家劫舍

打印 上一主题 下一主题

主题 840|帖子 840|积分 2520

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

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

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

络腮胡菲菲

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表