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

网站建设与维护蒋勇从黄冈论坛百度贴吧

网站建设与维护蒋勇从,黄冈论坛百度贴吧,温州公司建设网站制作,wordpress 审核用户309. 最佳买卖股票时机含冷冻期 动规五部曲 1、确定dp数组以及下标的含义 dp[i][j]#xff0c;第i天状态为j#xff0c;所剩的最多现金为dp[i][j]。 具体可以区分出如下四个状态#xff1a; 状态一#xff1a;持有股票状态#xff08;今天买入股票#xff0c;或者是…309. 最佳买卖股票时机含冷冻期 动规五部曲 1、确定dp数组以及下标的含义 dp[i][j]第i天状态为j所剩的最多现金为dp[i][j]。 具体可以区分出如下四个状态 状态一持有股票状态今天买入股票或者是之前就买入了股票然后没有操作一直持有不持有股票状态这里就有两种卖出股票状态 状态二保持卖出股票的状态两天前就卖出了股票度过一天冷冻期。或者是前一天就是卖出股票状态一直没操作状态三今天卖出股票状态四今天为冷冻期状态但冷冻期状态不可持续只有一天j的状态为 0状态一1状态二2状态三3状态四 注意这里的每一个状态例如状态一是持有股票股票状态并不是说今天一定就买入股票而是说保持买入股票的状态即可能是前几天买入的之后一直没操作所以保持买入股票的状态。  2、确定递推公式 达到买入股票状态状态一即dp[i][0]有两个具体操作 操作一前一天就是持有股票状态状态一dp[i][0] dp[i - 1][0]操作二今天买入了有两种情况 前一天是冷冻期状态四dp[i - 1][3] - prices[i]前一天是保持卖出股票的状态状态二dp[i - 1][1] - prices[i] 那么dp[i][0] max(dp[i - 1][0], dp[i - 1][3] - prices[i], dp[i - 1][1] - prices[i]); 达到保持卖出股票状态状态二即dp[i][1]有两个具体操作 操作一前一天就是状态二操作二前一天是冷冻期状态四 dp[i][1] max(dp[i - 1][1], dp[i - 1][3]); 达到今天就卖出股票状态状态三即dp[i][2] 只有一个操作 昨天一定是持有股票状态状态一今天卖出 即dp[i][2] dp[i - 1][0] prices[i]; 达到冷冻期状态状态四即dp[i][3]只有一个操作 昨天卖出了股票状态三 dp[i][3] dp[i - 1][2]; 3、dp数组如何初始化 如果是持有股票状态状态一那么dp[0][0] -prices[0]一定是当天买入股票。 保持卖出股票状态状态二只能初始为0 今天卖出了股票状态三同上分析dp[0][2]初始化为0dp[0][3]也初始为0。 4、确定遍历顺序 从递归公式上可以看出dp[i] 依赖于 dp[i-1]所以是从前向后遍历。 5、举例推导dp数组 以 [1,2,3,0,2] 为例dp数组如下 最后结果是取 状态二状态三和状态四的最大值 状态四是冷冻期最后一天如果是冷冻期也可能是最大值。  class Solution { public:int maxProfit(vectorint prices) {if (prices.size() 0) return 0;int len prices.size();vectorvectorint dp(len, vectorint(4,0));dp[0][0] -prices[0];for (int i 1; i len; i) {dp[i][0] max(dp[i - 1][0], max(dp[i - 1][3] - prices[i],dp[i - 1][1] - prices[i]));dp[i][1] max(dp[i - 1][1], dp[i - 1][3]);dp[i][2] dp[i - 1][0] prices[i];dp[i][3] dp[i - 1][2];}return max(dp[len - 1][1], max(dp[len - 1][2], dp[len - 1][3]));} }; 714. 买卖股票的最佳时机含手续费 与普通买卖股票问题一致手续费可以放在买入股票时也可以放在卖出股票时进行计算 本题把手续费算入买入股票时 动规五部曲 1、确定dp数组以及下标的含义 dp[i][j]第i天状态为j所剩的最多现金为dp[i][j]。 可以分为两种状态状态一不持有股票j为0状态二持有股票j为1 2、确定递推公式 不持有股票状态有两种情况 昨天不持有昨天持有今天把昨天股票卖出 dp[i][0] max(dp[i - 1][0], dp[i - 1][1] prices[i] 持有股票状态 昨天已持有昨天未持有今天买入股票 dp[i][1] max(dp[i - 1][1], dp[i - 1][0] - prices[i] - fee) 3、dp数组如何初始化 不持有股票 dp[0][0] 0; 持有股票 dp[0][1] -prices[0] - fee; 4、确定遍历顺序 从递归公式上可以看出dp[i] 依赖于 dp[i-1]所以是从前向后遍历。 5、举例推导dp数组 以 prices [1, 3, 2, 8, 4, 9], fee 2 为例 class Solution { public:int maxProfit(vectorint prices, int fee) {if (prices.size() 0) return 0;vectorvectorint dp(prices.size(), vectorint(2,0));dp[0][0] 0;dp[0][1] -prices[0] - fee;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], dp[i - 1][0] - prices[i] - fee);}return max(dp[prices.size() - 1][0], dp[prices.size() - 1][1]);} };
http://www.w-s-a.com/news/91766/

相关文章:

  • 网站内容怎么做专业的企业管理软件
  • 深圳网站制作公司排名微网站和微信公共平台的区别
  • 权威的唐山网站建设扁平网站欣赏
  • 网站外链建设工作计划应用公园app免费制作
  • 东莞营销型网站建设全自动建站系统
  • 网络在线培训网站建设方案虚拟主机配置WordPress
  • 建设工程信息查询哪个网站好台州做优化
  • wordpress页面回收站位置台州做网站
  • 邢台市行政区划图seo咨询师招聘
  • 外贸网站建设案例网站建设优化开发公司排名
  • 恩施网站优化郑州有没有厉害的seo
  • 电子商务网站建设与管理期末考试题铜山区建设局网站
  • 怎么做非法彩票网站大兴安岭网站建设公司
  • 网站备案授权书模板海外如何淘宝网站建设
  • 网站开发提供源代码dedecms做网站教程
  • 怎么做国际网站首页erp系统一套大概多少钱
  • 做代理网站用什么软件建设网站的企业多少钱
  • 微企免费做网站360收录提交
  • 网站导航页怎么做wordpress数据库批量替换
  • wordpress站点更换域名自己做wordpress 模版
  • 怎么做虚拟的网站东莞常平邮编是多少
  • 电子商务网站和普通网站的区别正规网站建设多少费用
  • 郴州免费招聘网站前端好还是后端好
  • 织梦网站怎样做子域名20个中国风网站设计欣赏
  • wordpress网站搬简约创意logo图片大全
  • 叙述网站制作的流程石家庄58同城最新招聘信息
  • 南昌微信网站建设东莞网站优化软件
  • 爱站数据官网纯静态网站挂马
  • 网站建设公司未来方向3d设计网站
  • 建设部网站 干部学院 一级注册建筑师培训 2014年做网站开发的提成多少钱