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

网站做二维码吗宣传推广的十种方式

网站做二维码吗,宣传推广的十种方式,网站建设南昌,杭州网页设计公司排行题目链接 买卖股票的最佳时机III 题目描述 注意点 1 < prices.length < 1000000 < prices[i] < 100000不能同时参与多笔交易&#xff08;必须在再次购买前出售掉之前的股票&#xff09;最多可以完成 两笔 交易 解答思路 本题最多可以完成两笔交易&#xff0c;…

题目链接

买卖股票的最佳时机III

题目描述


注意点

  • 1 <= prices.length <= 100000
  • 0 <= prices[i] <= 100000
  • 不能同时参与多笔交易(必须在再次购买前出售掉之前的股票)
  • 最多可以完成 两笔 交易

解答思路

  • 本题最多可以完成两笔交易,所以在任意一天,都会有五种状态,分别是无操作、第一次买入、第一次卖出、第二次买入、第二次卖出。需要注意的是,当天同时买入卖出是无意义的,利润不会改变,仅仅是增加了交易次数,不在考虑范围之内。同时无操作的利润始终为0,可以忽略不记,所以将每一天都分割成其余四种状态
  • 关键是怎么通过第i - 1天推出第i天四种状态的最大利润,可以分为以下几种
    • 当处于第一次买入的状态,其可能是当天购入也可能是之前就已经购入,取决于哪天购买的成本更低,所以dp[i][0] = Math.max(dp[i - 1][0], -prices[i]),注意当天购入的话需要花费prices[i]的成本,所以为负数
    • 当处于第一次卖出的状态,其可能是当天买出也可能是之前就已经卖出,取决于哪天卖出的利润更高,所以dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0] + prices[i]),dp[i - 1][0]是第一次购买最低的成本,其可以保证当天卖出在前i天当中所得到的利润是最大的
    • 当处于第二次买入的状态,其与第一次买入的状态类似,区别是第一次已经交易成功了,所以如果当天买入的话dp[i][2]的值还要加上第一次交易所得到的最大利润,也就是dp[i - 1][1],所以dp[i][2] = Math.max(dp[i - 1][2], dp[i - 1][1] - prices[i])
    • 当处于第二次卖入的状态,其与第二次卖出的状态类似,dp[i][3] = Math.max(dp[i - 1][3], dp[i - 1][2] + prices[i])
  • 需要注意的是,dp[0][2]与dp[0][0]一样,初始需要给默认值-prices[0],在第一次交易未完成时,dp[i][2]实际上始终与dp[i][0]相同,dp[i][3]与dp[i][1]也是如此,实际上此时第二次交易也是第一次交易(因为dp[i - 1][1]始终都为0,此时dp[i][2] = Math.max(dp[i - 1][2], - prices[i]))。当第一次交易完成时,dp[i][2]就需要在第一次交易获得利润的基础上进行考虑,其购买的成本会变为dp[i - 1][1] - prices[i]

代码

class Solution {public int maxProfit(int[] prices) {int n = prices.length;// 二维数组,dp[i][j]表示第i天时处于第j中状态的最大利润/*** j有以下四种状态* 0:第一次买入股票* 1:第一次卖出股票(也就是完成第一次交易)* 2:第二次买入股票* 3:第二次卖出股票(也就是完成第二次交易)* 不做任何操作也是一种状态,但是对结果无影响不考虑*/int[][] dp = new int[n][4];dp[0][0] = -prices[0];dp[0][2] = -prices[0];for (int i = 1; i < n; i++) {// 第i天购买或者之前就已购买,取购买花费更低的成本dp[i][0] = Math.max(dp[i - 1][0], -prices[i]);// 第i天卖出或者之前就已卖出,取卖出得到更高的利润dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0] + prices[i]);// 第i天购买或者之前就已购买,取购买花费更低的成本,第二次交易还要加上第一次交易所得的利润dp[i][2] = Math.max(dp[i - 1][2], dp[i - 1][1] - prices[i]);// 第i天卖出或者之前就已卖出,取卖出得到更高的利润dp[i][3] = Math.max(dp[i - 1][3], dp[i - 1][2] + prices[i]);}return Math.max(dp[n - 1][1], dp[n - 1][3]);}
}

关键点

  • 动态规划的思想
  • 每天买卖股票的四种状态
  • 怎么根据dp[i - 1][j]推出dp[i][j]
http://www.hengruixuexiao.com/news/16694.html

相关文章:

  • 济南地区做公司网站的公司百度seo推广怎么做
  • 阿里云服务器做网站百度app手机版
  • WordPress怎么批量上传图片seo排名培训学校
  • 石家庄学做网站建设培训班营销策划机构
  • python可以做动态网站吗百度广告投放技巧
  • 网站建设公司为什么没有官网制作网站的步骤
  • 张家港手机网站信息流广告投放公司
  • 公众号网站制作搜索引擎优化seo是什么
  • 怎么生成网页白帽优化关键词排名seo
  • 如何提供网站建设公司怎样在百度上做广告
  • 做网站虚拟主机企业网站的基本功能
  • 独立网站推广公司东莞百度seo排名
  • 安庆做网站的公司关键词查网址
  • 建设工程其它费计算网站百seo排名优化
  • 吉安高端网站建设公司百度手机助手app免费下载
  • 网站安全检测漏洞扫描风险等级输入关键词搜索
  • android 网站模板php视频转码
  • 北京住建网站龙岗网站推广
  • 百度收录正常网站流量下降泉州seo培训
  • 复制表格到wordpress宁波seo外包
  • wordpress首页缓存杭州网站关键词排名优化
  • 阿里云企业建站教程长沙营销网站建设
  • 合肥市中小企业局网站青岛关键词搜索排名
  • ppt素材模板免费下载高中同步测控优化设计答案
  • 如何做网站展示商品亚洲足球最新排名
  • 找人做网站设计 哪个平台可以找网页怎么制作
  • 旅游微网站分销苏州排名搜索优化
  • 笑话网站 wordpress深圳网站开发制作
  • 开发网站企业aso优化推广公司
  • 自己做音乐网站西安网站制作