力扣 188. 买卖股票的最佳时机 IV

题目来源:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-iv/description/

C++题解:动态规划

思路同力扣 123. 买卖股票的最佳时机 III-CSDN博客,只是把最高2次换成k次。如果思路不清晰,可以将k从0写到4等找找规律。

cpp 复制代码
class Solution {
public:
    int maxProfit(int k, vector<int>& prices) {
        int n = prices.size();
        if(n <= 1) return 0;
        // dp[i][j], 当j为偶数表示第j/2+1次买入,奇数表示(j+1)/2次卖出
        vector< vector<int> > dp(n, vector<int>(2*k, 0));
        for(int j = 0; j < k; j++) {
            dp[0][j*2] = -prices[0]; //初始化
        }
        for(int i = 1; i < n; i++) {
            dp[i][0] = max(dp[i-1][0], -prices[i]);
            for(int j = 1; j < k; j++){
                dp[i][2*j] = max(dp[i-1][2*j], dp[i-1][2*j-1] - prices[i]);
            }
            for(int m = 0; m < k; m++) {
                dp[i][2*m+1] = max(dp[i-1][2*m+1], dp[i-1][2*m] + prices[i]);
            }
        }
        return dp[n-1][2*k-1];
    }
};
相关推荐
编啊编程啊程4 小时前
JUC之AQS
java·开发语言·jvm·c++·kafka
2501_924889557 小时前
商超高峰客流统计误差↓75%!陌讯多模态融合算法在智慧零售的实战解析
大数据·人工智能·算法·计算机视觉·零售
jingfeng5147 小时前
C++模板进阶
java·c++·算法
头发掉光的程序员8 小时前
第七章 利用Direct3D绘制几何体
c++·windows·图形渲染·direct12
地平线开发者8 小时前
征程 6X | 常用工具介绍
算法·自动驾驶
地平线开发者8 小时前
理想汽车智驾方案介绍 2|MindVLA 方案详解
算法·自动驾驶
艾莉丝努力练剑9 小时前
【C语言16天强化训练】从基础入门到进阶:Day 7
java·c语言·学习·算法
地平线开发者9 小时前
LLM 中评价指标与训练概要介绍
算法·自动驾驶
Ghost-Face9 小时前
关于并查集
算法
flashlight_hi11 小时前
LeetCode 分类刷题:2529. 正整数和负整数的最大计数
python·算法·leetcode