动态规划31(Leetcode188买卖股票的最佳时机4)

代码:

我的状态方程:

buy[i][j]=max{buy[i−1][j],sell[i−1][j-1]−price[i]}

题解里的:

buy[i][j]=max{buy[i−1][j],sell[i−1][j]−price[i]}

..没理解题解的 但我的通过了

java 复制代码
class Solution {
    public int maxProfit(int k, int[] prices) {
        if(prices.length==0)return 0;
        int n = prices.length;
        k = Math.min(k,n/2);
        if(k==0)return 0;
        int[][] buy = new int[n][k];
        int[][] sell = new int[n][k];
        buy[0][0]=-prices[0];
        sell[0][0]=0;
        for(int i=1;i<k;i++){
            buy[0][i] = sell[0][i] = Integer.MIN_VALUE / 2;
        }
        for(int i=1;i<n;i++){
            buy[i][0] = Math.max(buy[i-1][0],-prices[i]);
            sell[i][0] = Math.max(sell[i-1][0],buy[i-1][0]+prices[i]);
            for(int j=1;j<k;j++){
                buy[i][j] = Math.max(sell[i-1][j-1]-prices[i],buy[i-1][j]);
                sell[i][j] = Math.max(buy[i-1][j]+prices[i],sell[i-1][j]);
            }
        }
        return Arrays.stream(sell[n-1]).max().getAsInt();
    }
}
相关推荐
hansang_IR4 分钟前
【记录】四道双指针
c++·算法·贪心·双指针
_OP_CHEN7 分钟前
算法基础篇:(十二)基础算法之倍增思想:从快速幂到大数据运算优化
大数据·c++·算法·acm·算法竞赛·倍增思想
CoovallyAIHub28 分钟前
分割万事万物的AI,再进化!Meta SAM 3 来了,支持中文提示词!
深度学习·算法·计算机视觉
九年义务漏网鲨鱼28 分钟前
蓝桥杯算法——记忆化搜索
算法·职场和发展·蓝桥杯
04aaaze35 分钟前
C++(C转C++)
c语言·c++·算法
Swift社区1 小时前
LeetCode 429 - N 叉树的层序遍历
算法·leetcode·职场和发展
星释1 小时前
Rust 练习册 32:二分查找与算法实现艺术
开发语言·算法·rust
zl_vslam1 小时前
SLAM中的非线性优-3D图优化之四元数在Opencv-PNP中的应用(五)
人工智能·算法·计算机视觉
机器学习之心1 小时前
经典粒子群优化算法PSO-LSTM回归+SHAP分析+多输出+新数据预测!Matlab代码实现
算法·lstm·pso-lstm·shap分析
小青龙emmm2 小时前
2025级C语言第四次周测题解
c语言·开发语言·算法