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

科技通信网站模板下载宿迁网络推广公司

科技通信网站模板下载,宿迁网络推广公司,网站返回404是什么意思,wordpress调用分类文章列表LeetCode 122 买卖股票的最佳时机 II 给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。 在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。 返回…

LeetCode 122 买卖股票的最佳时机 II

给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。
在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。
返回 你能获得的 最大 利润 。

问题转换 + 贪心

只要明天比今天价格高就在今天买入明天卖出,吃掉所有收益一定能达成题意要求的收益

class Solution:def maxProfit(self, prices: List[int]) -> int:res = 0if len(prices) == 1:return resfor i in range(1, len(prices)):tmp = prices[i] - prices[i - 1]res += (tmp if tmp > 0 else 0)return res

动态规划

下面网友写的题解十分精彩,从状态转移方程可以看出计算i只需i-1,可以进行滚动优化

作者:liweiwei1419
链接:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-ii/solutions/38498/tan-xin-suan-fa-by-liweiwei1419-2/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

第 1 步:定义状态

状态 dp[i][j] 定义如下:

dp[i][j] 表示到下标为 i 的这一天,持股状态为 j 时,我们手上拥有的最大现金数。

注意:限定持股状态为 j 是为了方便推导状态转移方程,这样的做法满足 无后效性。

其中:

第一维 i 表示下标为 i 的那一天( 具有前缀性质,即考虑了之前天数的交易 );
第二维 j 表示下标为 i 的那一天是持有股票,还是持有现金。这里 0 表示持有现金(cash),1 表示持有股票(stock)。

第 2 步:思考状态转移方程

状态从持有现金(cash)开始,到最后一天我们关心的状态依然是持有现金(cash);
每一天状态可以转移,也可以不动。状态转移用下图表示:
在这里插入图片描述
(状态转移方程写在代码中)

说明:

由于不限制交易次数,除了最后一天,每一天的状态可能不变化,也可能转移;
写代码的时候,可以不用对最后一天单独处理,输出最后一天,状态为 0 的时候的值即可。

第 3 步:确定初始值

起始的时候:

如果什么都不做,dp[0][0] = 0;
如果持有股票,当前拥有的现金数是当天股价的相反数,即 dp[0][1] = -prices[i];

第 4 步:确定输出值

终止的时候,上面也分析了,输出 dp[len - 1][0],因为一定有 dp[len - 1][0] > dp[len - 1][1]。

public class Solution {public int maxProfit(int[] prices) {int len = prices.length;if (len < 2) {return 0;}// 0:持有现金// 1:持有股票// 状态转移:0 → 1 → 0 → 1 → 0 → 1 → 0int[][] dp = new int[len][2];dp[0][0] = 0;dp[0][1] = -prices[0];for (int i = 1; i < len; i++) {// 这两行调换顺序也是可以的dp[i][0] = Math.max(dp[i - 1][0], dp[i - 1][1] + prices[i]);dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0] - prices[i]);}return dp[len - 1][0];}
}

复杂度分析:

时间复杂度:O(N),这里 N 表示股价数组的长度;
空间复杂度:O(N),虽然是二维数组,但是第二维是常数,与问题规模无关。

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

相关文章:

  • 做视频的网站软件设计就业方向及前景
  • 怎样创建官方网站近期新闻事件
  • 郑州网站排名优化公司网页制作下载链接怎么做
  • 深圳网站建设软件定制公司上海网站建设明细表
  • 杭州拱墅区网站建设网站图片尺寸
  • 在word上怎么做网站链接网易云课堂的网站建设特点
  • 新建网站的评估网站建设的目的是什么
  • 做网站公司排名企业网络推广哪家公司好
  • 怎样删除网站虚拟主机内容如何查看网站是否被降权
  • 浙江建设网站是多少58黄页网推广效果怎样
  • 网站上传大文件wordpress active
  • 大图做网站背景加载慢宁波网站建设流程图
  • 医院 网站后台管理wordpress 插件配置
  • 惠城网站制作微网站地图定位
  • 做网站如何来钱网站安全认证去哪做
  • 网站统计如何做2021东莞封城最新消息
  • 网站建设程序员提成php网站做安卓客户端
  • 网站被墙的原因免费流量平台哪个最好
  • 哪里有做推文的网站网站模板抄袭
  • 农村电子商务网站建设中小型企业网络搭建案例
  • 网站开发框架 开源手机网站seo
  • 贵阳企业自助建站系统专门做宠物食品的网站
  • 网站首页快照不更新做网站推广产品
  • 宁波住房和城乡建设培训网站网站建设与推广培训学校
  • 网站建设定金合同范本合肥关键词快速排名
  • 网站建设代理商电话重庆网站设计软件
  • 新乡做网站的潍坊网站建设推广报价
  • 做网站互联网公司手机logo免费设计软件
  • 网站运营与推广门户网站建设议题汇报材料
  • 做网站必须学php吗网站建设规划书百度文库