代码随想录算法训练营day42|动态规划part9

今天的第一题和第三题都比较简单,只需在前面的题目的代码上略加修改即可。第二题是有冷冻期的股票问题,这题的状态分析比前面的题目难不少。

卡哥的做法是分为四个状态,分别是持有股票,保持不持有股票的状态,卖出股票的状态以及冷冻期4个状态。根据定义可列出状态转移方程如下:

复制代码
dp[i][0] = max(dp[i - 1][0], max(dp[i - 1][3], dp[i - 1][1]) - 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];

这题非常巧妙的地方在于相较于前面两题,这题将保持不持有股票的状态和卖出股票的状态分开,这样有利于进行冷冻期的操作。

接下来进行初始化,dp[0][0]的意思是在第0天持有股票时的现金,自然是0.接着dp[0][1],这里不能直接根据字面意思推断,是因为这里dp[0][1]本身没有意义,所以要根据状态转移方程推导出dp[0][1]=0,因为如果初始化为其它数值答案都不正确。

我自己用的方法是用flag标记冷冻期,然后分类讨论:

复制代码
 vector<vector<int>>dp(prices.size(),vector<int>(2,0));
        int flag=0;//标记冷冻期状态
        dp[0][0]=0;
        dp[0][1]=-prices[0];
        //0表示卖出,1表示买入;
        for(int i=1;i<prices.size();i++){
            
            if(flag==0||i<2){
                dp[i][1]=max(dp[i-1][1],dp[i-1][0]-prices[i]);
            }
               else if(flag==1&&i>=2){//防止数组越界
               // dp[i][0]=max(dp[i-2][0],dp[i-2][1]+prices[i]);
                dp[i][1]=max(dp[i-2][1],dp[i-2][0]-prices[i]);
                flag=0;//在冷冻期后的一次处理后更新冷冻期状态
           }
           dp[i][0]=max(dp[i-1][0],dp[i-1][1]+prices[i]);
            if(dp[i][0]==dp[i-1][1]+prices[i]) {
                    flag=1;//更新冷冻期状态
                }
            
        }

但是卡哥的思路还是更为直观的

相关推荐
代码雕刻家10 分钟前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯
Ulyanov19 分钟前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
智者知已应修善业2 小时前
【查找字符最大下标以*符号分割以**结束】2024-12-24
c语言·c++·经验分享·笔记·算法
91刘仁德2 小时前
c++类和对象(下)
c语言·jvm·c++·经验分享·笔记·算法
diediedei2 小时前
模板编译期类型检查
开发语言·c++·算法
阿杰学AI2 小时前
AI核心知识78——大语言模型之CLM(简洁且通俗易懂版)
人工智能·算法·ai·语言模型·rag·clm·语境化语言模型
mmz12073 小时前
分治算法(c++)
c++·算法
睡一觉就好了。3 小时前
快速排序——霍尔排序,前后指针排序,非递归排序
数据结构·算法·排序算法
Tansmjs3 小时前
C++编译期数据结构
开发语言·c++·算法
金枪不摆鳍3 小时前
算法-字典树
开发语言·算法