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

深圳做网站哪个好晚上正能量免费下载软件安全

深圳做网站哪个好,晚上正能量免费下载软件安全,制作WordPress友情链接,微信群推广平台文档讲解:代码随想录 视频讲解:代码随想录B站账号 状态:看了视频题解和文章解析后做出来了 123.买卖股票的最佳时机III class Solution:def maxProfit(self, prices: List[int]) -> int:if len(prices) 0:return 0dp [[0] * 5 for _ in…

文档讲解:代码随想录

视频讲解:代码随想录B站账号

状态:看了视频题解和文章解析后做出来了

123.买卖股票的最佳时机III

class Solution:def maxProfit(self, prices: List[int]) -> int:if len(prices) == 0:return 0dp = [[0] * 5 for _ in range(len(prices))]dp[0][1] = -prices[0]dp[0][3] = -prices[0]for i in range(1, len(prices)):dp[i][0] = dp[i-1][0]dp[i][1] = max(dp[i-1][1], dp[i-1][0] - prices[i])dp[i][2] = max(dp[i-1][2], dp[i-1][1] + prices[i])dp[i][3] = max(dp[i-1][3], dp[i-1][2] - prices[i])dp[i][4] = max(dp[i-1][4], dp[i-1][3] + prices[i])return dp[-1][4]
  • 时间复杂度:O(n)
  • 空间复杂度:O(n)

1. 确定dp数组以及下标的含义

这道题有点变态了,dp需要5个状态。

dp[i][0]代表一开始不持有股票的状态,1代表第一次持有,2代表第一次卖出后不持有的状态,3代表第二次持有,4代表第二次卖出后不持有的状态。

2. 确定递推公式

dp[i][1] = max(dp[i-1][1], dp[i-0] - prices[i])

dp[i][2] = max(dp[i-1][2], dp[i-1] + prices[i])

老样子,持有的时候递推为前一天持有状态下的现金和前一天不持有今天买入的现金之间的较大者。第一次卖出的状态递推为前一天此状态和前一天持有今天卖出之间的较大值。

第二次交易同理,就不再写一遍了。

3. dp数组的初始化

(1) 第0天持有股票,那肯定是买入,所以初始化为-prices[i]

(2) 第0天不持有股票,那就是什么也没干,初始化为0

第二次持有股票,和第一次一样初始化为-prices[i]

第二次不持有股票,其实就是买卖了两次,所以初始化为0

4. 遍历顺序

递推公式中有i-1,所以从前往后遍历

5. dp数组举例

188.买卖股票的最佳时机IV 

class Solution:def maxProfit(self, k: int, prices: List[int]) -> int:if len(prices) == 0:return 0dp = [[0]*(k*2+1) for _ in range(len(prices))]for i in range(k):dp[0][i*2+1] = -prices[0]for i in range(1, len(prices)):for j in range(k*2+1):if j == 0:dp[i][j] = dp[i-1][j]elif j % 2 == 1:dp[i][j] = max(dp[i-1][j], dp[i-1][j-1] - prices[i])else:dp[i][j] = max(dp[i-1][j], dp[i-1][j-1] + prices[i])return dp[-1][k*2]
  • 时间复杂度:O(n)
  • 空间复杂度:O(n)

这题没啥好说的,就是上面那道题的变种,而且变得不是那么高明。

这次规定可以交易k次。那很简单啊,初始化和递归的index之前都是直接hardcode出来,这道题用一个for循环就行了。其他的全都一样。

http://www.yayakq.cn/news/483701/

相关文章:

  • 怎么选择锦州网站建设邢台网站制作公司
  • 做网站一年能赚多少钱营销的三个基本概念是什么
  • 泰安网站建设企业精美网站制作公司
  • php企业网站源码下载网站策划书包含的内容
  • 赚钱做任务的网站有哪些电子商务都包括什么
  • 营口旅游网站开发网站优化建设公司
  • 电商网站开发人员Godaddy如何建设网站
  • 网站收录提交入口wordpress二维码手工
  • 企业网站设计步骤建设银行有招投标网站吗
  • 可信赖的宜昌网站建设范县网站建设公司
  • 国内常见的博客网站网站可以自己建立吗
  • 网站描述标签长沙哪里做网站
  • 专业摄影网站推荐廊坊做网站的企业哪家好
  • 网站做404是什么意思百度平台投诉人工电话
  • 企业营销策划心得体会长沙网站优化培训
  • 天空在线网站建设中国软件
  • 广州网站开发定制设计wordpress输出分类
  • 建设网站的基本流程安徽省住房城乡建设厅网站官网
  • 网站备案费一般是多少内蒙古建设工程造价信息网解释
  • 福州有名的公司网站设计南京前十名传媒广告公司
  • 织梦快速做双语网站做外贸主要在那些网站找单
  • 团购网站短信平台wordpress多媒体mp4
  • 商业网站缩写专业手机网站建设平台
  • 山东网站建设设计哈尔滨百度推广排名优化
  • 莲花网站建设桂林市建设工程质量监督站网站
  • 网站开发工具最适合厦门开发网站公司
  • 360网站做二维码做课展网站
  • 腾讯企业网站建设手机无法登录wordpress
  • 网站图标怎么下载有哪些做短租的网站
  • 网站建设为什么必须有服务器网站seo招聘