买卖股票的最佳时期含冷冻期(leetcode)

个人主页:Lei宝啊

愿所有美好如期而遇


也就有这样的状态转移方程:

  • 买入:dp[i][0] = max(dp[i-1][1] - prices[i], dp[i-1][0]);
  • 可买入:dp[i][1] = max(dp[i-1][1], dp[i-1][2]);
  • 冷冻期:dp[i][2] = dp[i-1][0] + prices[i];
cpp 复制代码
class Solution 
{
public:
    int maxProfit(vector<int>& prices) 
    {
        vector<vector<int>> dp(prices.size(), vector<int>(3));
        dp[0][0] = -prices[0];

        for(int i=1; i<prices.size(); i++)
        {
            dp[i][0] = max(dp[i-1][1] - prices[i], dp[i-1][0]);
            dp[i][1] = max(dp[i-1][1], dp[i-1][2]);
            dp[i][2] = dp[i-1][0] + prices[i];
        }

        int ret = max(dp[prices.size()-1][1], dp[prices.size()-1][2]);
        return ret;
    }
};
相关推荐
牵手夏日1 小时前
题目类型——左右逢源
算法
愚润求学2 小时前
【递归、搜索与回溯】FloodFill算法(一)
c++·算法·leetcode
sunny-ll4 小时前
【C++】详解vector二维数组的全部操作(超细图例解析!!!)
c语言·开发语言·c++·算法·面试
嵌入式@秋刀鱼5 小时前
《第四章-筋骨淬炼》 C++修炼生涯笔记(基础篇)数组与函数
开发语言·数据结构·c++·笔记·算法·链表·visual studio code
嵌入式@秋刀鱼5 小时前
《第五章-心法进阶》 C++修炼生涯笔记(基础篇)指针与结构体⭐⭐⭐⭐⭐
c语言·开发语言·数据结构·c++·笔记·算法·visual studio code
简简单单做算法5 小时前
基于PSO粒子群优化的VMD-LSTM时间序列预测算法matlab仿真
算法·matlab·lstm·时间序列预测·pso·vmd-lstm·pso-vmd-lstm
无聊的小坏坏5 小时前
高精度算法详解:从原理到加减乘除的完整实现
算法
愚润求学5 小时前
【递归、搜索与回溯】FloodFill算法(二)
c++·算法·leetcode
泽02025 小时前
C++之list的自我实现
开发语言·数据结构·c++·算法·list
南枝异客6 小时前
四数之和-力扣
java·算法·leetcode