LeetCode309:买卖股票的最佳时机含冷冻期

题目链接:309. 买卖股票的最佳时机含冷冻期 - 力扣(LeetCode)

代码如下

复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int len = prices.size();
        if(len == 0)    return 0;
        vector<vector<int> > dp(len, vector<int>(4, 0));
        //dp[i][0]持有股票状态
        //dp[i][1]保持卖出股票状态
        //dp[i][2]卖出股票状态
        //dp[i][3]冷冻期
        //dp[i][0] = max(dp[i - 1][0], dp[i - 1] - price[i], dp[i - 1][3] - price[i]);
        //dp[i][1] = max(dp[i - 1][1], dp[i - 1][3]);
        //dp[i][2] = dp[i - 1][0] + price[i];
        //dp[i][3] = dp[i - 1][2];
        dp[0][0] -= prices[0];
        for(int i = 1; i < len; i++)
        {
            dp[i][0] = max(dp[i - 1][0], max(dp[i - 1][1] - prices[i], dp[i - 1][3] - 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]));
    }
};

这个题目就是需要把冷冻期也算作是一个状态,然后把卖出的情况再分成两个状态,总共四个状态,这个时候就是需要我们去分析每个状态的状态转移方程

dp的含义

//dp[i][0]持有股票状态

//dp[i][1]保持卖出股票状态

//dp[i][2]卖出股票状态

//dp[i][3]冷冻期

状态转移方程

//dp[i][0] = max(dp[i - 1][0], dp[i - 1] - price[i], dp[i - 1][3] - price[i]);

这个我们可以这么来看,就是我持有这个股票,那我前一天可以是持有,但我此时需要减去当前我买去这个股票的现金,第二个就是我们的股票是不是前一天也可能是卖出股票的状态,这个时候就是我们需要在保持卖出股票的状态减去现金,其次是不是我们也有可能在冷冻期的时候,也就是过完冷冻期刚好这一天,我给买下了这个股票,然后减去现金

//dp[i][1] = max(dp[i - 1][1], dp[i - 1][3]);

这个第一种就是我们卖出股票的状态前一天也可以是保持卖出的,第二种就是我们也可以保持卖出股票之前是在冷冻期的时候。

//dp[i][2] = dp[i - 1][0] + price[i];

这个就是我们这一天卖出了,那么前一天肯定是买入的减去现金

//dp[i][3] = dp[i - 1][2];

这个就是我们的冷冻期,冷冻期的前一天肯定是卖出股票的状态的,因为卖出这个股票了,立马进入冷冻期了。

初始化:

dp[0][0] -= prices[0];

这个其实很好理解,因为你想要持有,那么就要减去这个现金数

dp[0][1] = 0

这个也很好理解,因为当前这个状态是你保持卖出这个股票,你肯定不会去做亏本买卖吧,所以你肯定是赚钱的数量大于等于0,初始化为0就好

dp[0][2] = 0;

以此类推

dp[0][3] = 0;

以此类推

返回值;

这个为什么返回是这三个取最大值呢,有可能我这个冷冻期持续到我结束,也有可能我保持卖出股票持续要结束,也有可能我最后一天就是卖出这个股票了。

相关推荐
多喝开水少熬夜10 小时前
Trie树相关算法题java实现
java·开发语言·算法
WBluuue10 小时前
数据结构与算法:树上倍增与LCA
数据结构·c++·算法
bruk_spp10 小时前
牛客网华为在线编程题
算法
黑屋里的马12 小时前
java的设计模式之桥接模式(Bridge)
java·算法·桥接模式
sin_hielo12 小时前
leetcode 1611
算法·leetcode
李小白杂货铺13 小时前
识别和破除信息茧房
算法·信息茧房·识别信息茧房·破除信息茧房·算法推荐型茧房·观点过滤型茧房·茧房
来荔枝一大筐13 小时前
C++ LeetCode 力扣刷题 541. 反转字符串 II
c++·算法·leetcode
暴风鱼划水14 小时前
算法题(Python)数组篇 | 6.区间和
python·算法·数组·区间和
zl_vslam14 小时前
SLAM中的非线性优-3D图优化之轴角在Opencv-PNP中的应用(一)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
是苏浙14 小时前
零基础入门C语言之C语言实现数据结构之顺序表应用
c语言·数据结构·算法