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

哪个网站可以做行程建筑工程网校有哪些

哪个网站可以做行程,建筑工程网校有哪些,网站技术实现方案,免费推广选择推广途径与原因提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、打家劫舍二、打家劫舍2三、打家劫舍3 前言 提示:这里可以添加本文要记录的大概内容: 今天是跟着代码随想录刷题的第45天&#xff…

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、打家劫舍
  • 二、打家劫舍2
  • 三、打家劫舍3


前言

提示:这里可以添加本文要记录的大概内容:

今天是跟着代码随想录刷题的第45天,主要学习了打家劫舍的三个问题


提示:以下是本篇文章正文内容,下面案例可供参考

一、打家劫舍

思路:这一家最多能偷的是上一家偷的和上上家偷的加上自己这一家(因为上上家偷不偷,这一家都可以偷)

class Solution {
public:int rob(vector<int>& nums) {vector<int> dp(nums.size(),0);if(nums.size()==1) return nums[0];if(nums.size()==0) return 0;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];}
};

二、打家劫舍2

这道题的思想就是最前面和最后面只能要一个呗,这样的话我把要前面和要后面两个分开,要前面的不要后面,要后面的不要前面,然后取最大值就好了,这道题是编了一个函数来实现这样的一个过程。

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

三、打家劫舍3

思路:这里是结合了二叉树,用二叉树的搜索遍历,从下到上遍历,所以是后序遍历,用的是左右中,然后dp[0]是不偷这个最多能偷多少钱,dp[1]是偷这个东西,最多能偷多少钱,所以最后把根节点放进去,就是不偷根节点最多偷的钱数和偷根节点最多偷的钱数一比较,就可以得出来最终的结果。

class Solution {
public:int maxProfit(vector<int>& prices) {vector<vector<int>> dp(prices.size(),vector<int>(4));//dp[i][0]是第i天第一次不持有股最多有多少钱,dp[i][1]是第i天第一次持有股最多有多少钱,dp[i][2]是第i天第二次不持有股最多有多少钱,dp[i][3]是第i天第二次持有股最多有多少钱dp[0][0]=0;dp[0][1]=-prices[0];dp[0][2]=0;//考虑第0天,买了又卖又买又卖dp[0][3]=-prices[0];//考虑第0天,买了又卖又买for(int i=1;i<prices.size();i++){dp[i][0]=max(dp[i-1][0],dp[i-1][1]+prices[i]);//今天不持股,保持了昨天也不持或者昨天持股,今天卖了dp[i][1]=max(dp[i-1][1],-prices[i]);//今天持股,保持的昨天持股,或者今天刚买的,注意第一次持股直接是-price[i]dp[i][2]=max(dp[i-1][2],dp[i-1][3]+prices[i]);//今天第二次不持股,保持了昨天也是或者昨天第二次持股,今天卖了dp[i][3]=max(dp[i-1][3],dp[i-1][0]-prices[i]);//今天第二次持股,可能保持了昨天也可能昨天第一次刚不持股,然后立马买了}return max(max(max(dp[prices.size()-1][0],dp[prices.size()-1][1]),dp[prices.size()-1][2]),dp[prices.size()-1][3]);}
};
http://www.yayakq.cn/news/733525/

相关文章:

  • 成都网站建设哪家比较好网站建设一个多少钱
  • 高校招生网站模板购物网站建设方案ppt
  • 成品网站免费模板网站开发与设计的总体思想
  • pc做网站服务器做胎儿羊水鉴定网站
  • 小学学校网站建设培训资料贾汪网架公司
  • 网站模板管理系统绿色模板网站
  • asp网站相册免费做简历网站有哪些
  • 安康网站定制厂家个人网站创建平台要多少钱
  • 如何做单位网站营销活动方案名称
  • 梅林网站建设云邮企业邮箱官网
  • 个人网站首页设计优秀作品在互联网公司上班都做啥的
  • 用自己服务器做网站广东外贸网站推广
  • 面对不法网站该怎样做石家庄小程序开发公司
  • 营销型网站的特点有哪些服务器可以做网站吗
  • 中山网站外包京东网站建设吗
  • 能做wordpress的网站常州网站制作公司有哪些
  • 门户网站建设方案 模板网络推广的工作内容是什么
  • 网站建设所用程序郑州专业网站制作建设
  • 抖音网站怎么做怎么增加网站首页权重
  • 有做学历在网站能查的到的主机屋建网站源码
  • 搜索引擎网站录入网站套站什么意思
  • 做网站前端后端ui什么意思wordpress 点击富强
  • 淘宝网站是谁做的莱芜雪野湖风景区门票多少钱
  • wordpress不适合大型网站gate网站合约怎么做空
  • 河南智慧团建网站登录wordpress本地域名
  • 乡村旅游网站的建设分析学习软件免费
  • seo 成功网站做网络推广的网站有哪些
  • 网站地域分站怎么做企业网站建设费用需要多少钱
  • 中国十大品牌网站做网站需要提供什么资料
  • 可以免费做中考题的网站wordpress多条件