动态规划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();
    }
}
相关推荐
小蛋编程5 分钟前
【算法-图论】图的存储
c++·算法·图论
Maplesoft6 分钟前
符号计算与算法实践|使用Maple教授群论和图论课程
算法
今天你睡了嘛9 分钟前
数据结构——图(二、图的存储和基本操作)
数据结构·算法·图论
KyollBM9 分钟前
【CF】Day114——杂题 (贪心 + 图论 | LCM + 贪心 | 最大最小子序列 + 图论)
算法·图论
Alfred king39 分钟前
面试150 不同路径Ⅱ
矩阵·动态规划·数组
怀旧,1 小时前
【C++】1. C++基础知识
开发语言·c++·算法
Gerry_Liang1 小时前
LeetCode热题100——155. 最小栈
算法·leetcode·职场和发展
TechCampus2 小时前
小红书面试中我这样解释 KMP,面试官点头了
算法
Youndry2 小时前
验证二叉搜索树
算法
Spider_Man2 小时前
从 "字符拼图" 到 "文字魔术":动态规划玩转字符串变形术
javascript·算法·leetcode