算法训练营day53

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

复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices) {
        vector<vector<int>> dp(prices.size(), vector<int>(3));
        // 三个状态
        // dp[i][0] 持有股票  dp[i][1] 冷冻期  dp[i][2] 不持有股票
        // 递推公式
        // 持有股票 = max(前一次就持有,冷冻期-今天股票价格)
        // 冷冻期 = max(前一次冷冻期,持有股票)
        // 不持有股票 = max(前一次就不持有,持有股票+今天股票价格)
        dp[0][0] = - prices[0];
        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][2]);
            dp[i][2] = max(dp[i - 1][2], dp[i - 1][0] + prices[i]);
        }
        return dp[prices.size() - 1][2];
    }
};

题目2:714. 买卖股票的最佳时机含手续费 - 力扣(LeetCode)

这道题就是在 买卖股票Ⅱ上多了一个手续费而已

复制代码
class Solution {
public:
    int maxProfit(vector<int>& prices, int fee) {
        vector<vector<int>> dp(prices.size(), vector<int>(2));
        dp[0][0] = -prices[0];
        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 - 0][0] + prices[i] - fee);
        }
        return dp[prices.size() - 1][1];
    }
};
相关推荐
前端小L18 分钟前
动态规划的“数学之魂”:从DP推演到质因数分解——巧解「只有两个键的键盘」
算法·动态规划
RTC老炮32 分钟前
webrtc弱网-ReceiveSideCongestionController类源码分析及算法原理
网络·算法·webrtc
21号 134 分钟前
9.Redis 集群(重在理解)
数据库·redis·算法
码农多耕地呗1 小时前
力扣146.LRU缓存(哈希表缓存.映射+双向链表数据结构手搓.维护使用状况顺序)(java)
数据结构·leetcode·缓存
hadage2332 小时前
--- 数据结构 AVL树 ---
数据结构·算法
liu****2 小时前
8.list的使用
数据结构·c++·算法·list
阿拉丁的梦3 小时前
后期材质-屏幕冲击径向模糊
算法·材质
weixin_429630263 小时前
实验二-决策树-葡萄酒
算法·决策树·机器学习
茉莉玫瑰花茶4 小时前
floodfill 算法(dfs)
算法·深度优先
CoderCodingNo4 小时前
【GESP】C++五级考试大纲知识点梳理, (5) 算法复杂度估算(多项式、对数)
开发语言·c++·算法