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;

以此类推

返回值;

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

相关推荐
周杰伦_Jay3 分钟前
简洁明了:介绍大模型的基本概念(大模型和小模型、模型分类、发展历程、泛化和微调)
人工智能·算法·机器学习·生成对抗网络·分类·数据挖掘·transformer
凭君语未可15 分钟前
豆包MarsCode:小C点菜问题
算法
C语言魔术师35 分钟前
【小游戏篇】三子棋游戏
前端·算法·游戏
自由自在的小Bird35 分钟前
简单排序算法
数据结构·算法·排序算法
王老师青少年编程7 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
DogDaoDao7 小时前
leetcode 面试经典 150 题:有效的括号
c++·算法·leetcode·面试··stack·有效的括号
Coovally AI模型快速验证8 小时前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
可为测控8 小时前
图像处理基础(4):高斯滤波器详解
人工智能·算法·计算机视觉
Milk夜雨9 小时前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
BoBoo文睡不醒9 小时前
动态规划(DP)(细致讲解+例题分析)
算法·动态规划