代码随想录35期Day49-Java

Day49题目

LeetCode123买卖股票三

核心思想:和昨天的买卖股票相比,这个只允许买两次,因此把状态新增几个,可见代码注释

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        // 设置五个状态  0 : 无操作 , 1 : 第一次买入, 2 : 第一次卖出 , 3: 第二次买入, 4:第二次卖出
        // 这几个状态都是持续性的,表示目前进行到了哪个阶段,而不是当前天的动作
        int[][] dp = new int[prices.length][5];
        dp[0][0] = 0 ;
        dp[0][1] = -prices[0];
        dp[0][2] = 0;
        dp[0][3] = -prices[0];
        dp[0][4] = 0;
        for(int i =  1 ; i < prices.length ; i ++){
            dp[i][0] = 0;
            dp[i][1] = Math.max(dp[i-1][1],dp[i-1][0]-prices[i]);
            dp[i][2] = Math.max(dp[i-1][2],dp[i-1][1]+prices[i]);
            dp[i][3] = Math.max(dp[i-1][3],dp[i-1][2]-prices[i]);
            dp[i][4] = Math.max(dp[i-1][4],dp[i-1][3]+prices[i]); 
        }
        return dp[prices.length-1][4];
    }
}

LeetCode188买卖股票四

核心思想:和上面题目不同的是,你最多可以买K次股票,因此需要有2*k+1个状态,选择奇数为买入,偶数为卖出

java 复制代码
class Solution {
    public int maxProfit(int k, int[] prices) {
        // 奇数为买入
        // 偶数为卖出
        int[][] dp = new int[prices.length][2*k+1];
        for(int i = 1 ; i < 2*k+1 ; i +=2){
            dp[0][i] = -prices[0]; 
        }
        for(int i = 1 ; i < prices.length ; i ++){
            for(int j  = 1; j < 2*k+1;  j +=2  ){
                dp[i][j] = Math.max(dp[i-1][j],dp[i-1][j-1] - prices[i]);
                dp[i][j+1] = Math.max(dp[i-1][j+1], dp[i-1][j] + prices[i]);
            }
        }
        return dp[prices.length-1][2*k];
    }
}
相关推荐
AllData公司负责人12 小时前
亲测丝滑,体验跃迁|AllData通过集成开源项目Cube-Studio,降低机器学习落地门槛
java·大数据·数据库·人工智能·机器学习·开源·cube-studio
AI算法沐枫12 小时前
机器学习经典小项目4:泰坦尼克号生存预测
人工智能·python·深度学习·线性代数·算法·机器学习·回归
玖釉-12 小时前
单词搜索:二维网格中的 DFS 回溯与剪枝优化
c++·windows·算法·深度优先·剪枝
吴可可12312 小时前
C++与C#版Teigha样条离散化差异解析
c++·算法·c#
KaMeidebaby12 小时前
卡梅德生物技术快报|抗体的制备与纯化:分子实验实操:番茄 sHSP 重组表达与抗体的制备与纯化工艺
前端·数据库·人工智能·其他·算法·百度·新浪微博
zxd02031112 小时前
DevOps + CI/CD:从理念到 Jenkins 实战落地
java·开发语言
qq_白羊座12 小时前
GitLab CI + Jenkins 双流水线模式Jenkins 端实现
java·开发语言
填满你的记忆12 小时前
《RAG 完整工作流程详解》
java·ai·agent·rag
Kurisu57512 小时前
深度解析:Go 语言 GMP 调度器模型与内核线程探测
java·数据库·golang
架构源启12 小时前
Spring AI进阶系列(11) Spring AI Multi-Agent 协作系统:辩论、投票与共识机制实战
java·人工智能·spring