LeetCode—最佳买卖股票时机含冷冻期(DP)
程序员文章站
2022-03-07 20:13:43
最佳买卖股票时机含冷冻期(中等)2020年7月10日题目来源:力扣解题需要好好理解状态量是当前收益,有三种状态:持股状态、不持股的冷冻期状态、不持股的卖出状态class Solution { public int maxProfit(int[] prices) { int plen=prices.length; int[][] dp=new int[plen+1][3]; if(plen<2) return 0; //...
最佳买卖股票时机含冷冻期(中等)
2020年7月10日
题目来源:力扣
解题
需要好好理解状态量是当前收益,有三种状态:持股状态、不持股的冷冻期状态、不持股的卖出状态
class Solution {
public int maxProfit(int[] prices) {
int plen=prices.length;
int[][] dp=new int[plen+1][3];
if(plen<2) return 0;
//一开始是持股状态
dp[0][0]=-prices[0];
for(int i=1;i<plen;i++){
/*持股状态,第一种情况是上次持股了没卖,继续保持持股状态;
第二种情况是在卖出状态刚买的,进入持股状态*/
dp[i][0]=Math.max(dp[i-1][0],dp[i-1][2]-prices[i]);
/*不持股的冷冻状态,只能是持股卖出且获得收益的*/
dp[i][1]=dp[i-1][0]+prices[i];
/*不持股的卖出状态,第一种情况是不持股也没买,继续保持不持股状态;
第二种情况是刚过冷冻期,进入不持股的卖出状态*/
dp[i][2]=Math.max(dp[i-1][2],dp[i-1][1]);
}
//返回两种不持股状态哪个收益高
return Math.max(dp[plen-1][1],dp[plen-1][2]);
}
}
本文地址:https://blog.csdn.net/weixin_41541562/article/details/107249886
上一篇: XSL简明教程(6)XSL过滤和查询
下一篇: leetcode53. 最大子序和
推荐阅读
-
【leetcode】121 买卖股票的最佳时机(动态规划)
-
动态规划---买卖股票的最佳时机(LeetCode 70)
-
LeetCode 买卖股票的最佳时机 (动态规划)
-
【重拾算法~Leetcode每日一题】309.最佳买卖股票时机含冷冻期(难度:中等)
-
LeetCode刷题记录——第122题(买卖股票的最佳时机二)
-
LeetCode 714. 买卖股票的最佳时机含手续费 Python
-
Leetcode 714. 买卖股票的最佳时机含手续费
-
leetcode 714. 买卖股票的最佳时机含手续费
-
LeetCode:714. 买卖股票的最佳时机含手续费(python)
-
【leetcode】【medium】714. 买卖股票的最佳时机含手续费