当前位置: 首页 > news >正文

全国域名备案查询北京推广优化经理

全国域名备案查询,北京推广优化经理,wordpress 质感主题,杭州营销网站建设公司198.打家劫舍 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个…

198.打家劫舍

你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。

给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。

1)确定dp数组及下标含义

dp[i]:考虑下标i以内的房屋,最多可以偷窃的金额为dp[i]。

2)确定递推公式

决定dp[i]的因素就是第i房间偷还是不偷。

如果偷第i房间,那么dp[i] = dp[i - 2] + nums[i] ,即:第i-1房一定是不考虑的,找出 下标i-2(包括i-2)以内的房屋,最多可以偷窃的金额为dp[i-2] 加上第i房间偷到的钱。

如果不偷第i房间,那么dp[i] = dp[i - 1],即考虑i-1房。

然后dp[i]取最大值,即dp[i] = max(dp[i - 2] + nums[i], dp[i - 1])。

3)dp数组初始化

从递推公式dp[i] = max(dp[i - 2] + nums[i], dp[i - 1]);可以看出,递推公式的基础就是dp[0] 和 dp[1]

从dp[i]的定义上来讲,dp[0] 一定是 nums[0],dp[1]就是nums[0]和nums[1]的最大值即:dp[1] = max(nums[0], nums[1]);

4)确定遍历顺序

dp[i] 是根据dp[i - 2] 和 dp[i - 1] 推导出来的,那么一定是从前到后遍历!

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

213.打家劫舍

你是一个专业的小偷,计划偷窃沿街的房屋,每间房内都藏有一定的现金。这个地方所有的房屋都 围成一圈 ,这意味着第一个房屋和最后一个房屋是紧挨着的。同时,相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警 。

给定一个代表每个房屋存放金额的非负整数数组,计算你 在不触动警报装置的情况下 ,能够偷窃到的最高金额。

成环包含三种情况:

1)不包含首位元素

2)包含首元素,不包含尾元素

 

3)包含尾元素,不包含首元素

 

 

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

337.打家劫舍

在上次打劫完一条街道之后和一圈房屋后,小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为“根”。 除了“根”之外,每栋房子有且只有一个“父“房子与之相连。一番侦察之后,聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”。 如果两个直接相连的房子在同一天晚上被打劫,房屋将自动报警。

计算在不触动警报的情况下,小偷一晚能够盗取的最高金额。

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:unordered_map<TreeNode*,int> umap;int rob(TreeNode* root) {if(root==nullptr) return 0;if(root->left==nullptr&&root->right==nullptr) return root->val;if(umap[root]) return umap[root];int val1=root->val;if(root->left) val1+=rob(root->left->left)+rob(root->left->right);if(root->right) val1+=rob(root->right->left)+rob(root->right->right);int val2=rob(root->left)+rob(root->right);umap[root]=max(val1, val2);return max(val1, val2);}
};

http://www.wangmingla.cn/news/94893.html

相关文章:

  • 微信公众号上做网站每日关键词搜索排行
  • 乐清市龙翔网络工程公司宁波seo推荐优化
  • 云服务器网站解析免费创建个人网页
  • 网站开发颜色选择器滕州seo
  • 网站服务器怎么做安全防护湖南关键词网络科技有限公司
  • 劳力士官方二手表网站关键词优化话术
  • 农产品网站开发技术方案与设施郑州网站制作选择乐云seo
  • 建中英文网站关键词怎样做优化排名
  • 最新国家大事件中山seo
  • 金融审核网站制作站长工具无内鬼放心开车禁止收费
  • 做装修效果图的网站有哪些网络广告设计
  • 盘锦网站建设 盘锦建站推广 盘锦建站软文推广例子
  • 网站制作报价大约免费发布广告信息的网站
  • 网站开发 印花税自己有货源怎么找客户
  • 软件系统设计流程为什么seo工资不高
  • 1个月能学好网站开发吗搜索引擎排名2021
  • 新网站应该怎么做seo广州百度seo代理
  • dream网站怎么做框架seo网站结构优化的方法
  • 网站运营与管理的含义百度文章收录查询
  • 网站推广专家十年乐云seo网站开发详细流程
  • 小公司建网站 优帮云seo专业优化方法
  • 苏州做网站好的适合小学生的最新新闻
  • vs如何做网站推广营销平台
  • 网站如何做3d产品怎么能在百度上做推广
  • 老版本hao123上网导航广州百度seo 网站推广
  • 网站建设演讲稿厦门seo关键词优化代运营
  • aspcms手机网站怎么做企拓客软件怎么样
  • 中国制造网官方网站入口网址拓客软件哪个好用
  • 顺德公司做网站seo综合查询平台
  • 网站备案管理系统重庆关键词优化