代码随想录算法训练营第四十四天|leetcode309、714题

一、leetcode第309题

本题对于买卖股票加入了冷冻期的限制,因此设置dp数组分为四个状态:买入股票状态、卖出股票状态(两天前卖出股票或前一天卖出股票一直没有操作)、今天卖出股票状态、冷冻期状态。

具体代码如下:

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

二、leetcode第714题

本题与求买卖股票最大利润的区别仅在于加入了手续费,因此在不持有股票状态的递推公式中减去手续费即可。

具体代码如下:

cpp 复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices, int fee) {
    vector<vector<int>>dp(prices.size(),vector<int>(2,0));
    dp[0][0]=-prices[0];
    dp[0][1]=0;
    //dp[i][0]第i天持有股票
    //dp[i][1]第i天不持有股票
    for(int i=1;i<prices.size();i++)
    {
        dp[i][0]=max(dp[i-1][0],dp[i-1][1]-prices[i]);
        dp[i][1]=max(dp[i-1][1],dp[i-1][0]+prices[i]-fee);
    }
    return dp[prices.size()-1][1];
    }
};
相关推荐
爱吃生蚝的于勒1 小时前
C语言内存函数
c语言·开发语言·数据结构·c++·学习·算法
ChoSeitaku6 小时前
链表循环及差集相关算法题|判断循环双链表是否对称|两循环单链表合并成循环链表|使双向循环链表有序|单循环链表改双向循环链表|两链表的差集(C)
c语言·算法·链表
Fuxiao___7 小时前
不使用递归的决策树生成算法
算法
我爱工作&工作love我7 小时前
1435:【例题3】曲线 一本通 代替三分
c++·算法
白-胖-子7 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
workflower7 小时前
数据结构练习题和答案
数据结构·算法·链表·线性回归
好睡凯7 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法
Sunyanhui18 小时前
力扣 二叉树的直径-543
算法·leetcode·职场和发展
一个不喜欢and不会代码的码农8 小时前
力扣105:从先序和中序序列构造二叉树
数据结构·算法·leetcode
前端郭德纲8 小时前
浏览器是加载ES6模块的?
javascript·算法