算法学习day42-动态规划

买卖股票3

核心思路

  • 和买卖股票23一样
  • 区别只是变成k的可变的买卖次数了

解题代码

  • 二维数组

    java 复制代码
        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++) {
                    if (j % 2 == 0) {
                        dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1] + prices[i]);
                    } else {
                        dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1] - prices[i]);
                    }
                }
            }
            return dp[prices.length - 1][2 * k];
        }
  • 一维数组 其实和背包问题的一维数组解法思路一致

    java 复制代码
        public int maxProfit(int k, int[] prices) {
            int[] dp = new int[2 * k + 1];
            for (int i = 1; i < 2 * k + 1; i += 2) {
                dp[i] = -prices[0];
            }
            for (int i = 1; i < prices.length; i++) {
                for (int j = 1; j < 2 * k + 1; j++) {
                    if (j % 2 == 0) {
                        dp[j] = Math.max(dp[j], dp[j - 1] + prices[i]);
                    } else {
                        dp[j] = Math.max(dp[j], dp[j - 1] - prices[i]);
                    }
                }
            }
            return dp[2 * k];
        }

买卖股票4

核心思路

  • 这一题主要是多了个冻结期, 要把状态搞明白
java 复制代码
    //dp[i][0]: 持有股票的最大现金
    //dp[i][1]: 未持有股票之一: 前几天就卖了, 一直未持有的最大现金
    //dp[i][2]: 未持有股票之二: 今天才卖的剩余现金
    //dp[i][3]: 冷冻期 = dp[i-1][2]
    public int maxProfit(int[] prices) {
        int[][] dp = new int[prices.length][4];
        dp[0][0] = -prices[0];
        dp[0][1] = 0;
        dp[0][2] = 0;
        dp[0][3] = 0;
        for (int i = 1; i < prices.length; i++) {
            //持有股票的最大现金
            //1. 延续昨天的
            //2. 前一天的状态2, 即一直就没买的剩余最大现金 - price[i]
            //3. 前一天的冷冻期的现金 - price[i]
            dp[i][0] = Math.max(dp[i - 1][0], Math.max(dp[i - 1][1] - prices[i], dp[i - 1][3] - prices[i]));
            dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][3]);
            dp[i][2] = dp[i - 1][0] + prices[i];
            dp[i][3] = dp[i - 1][2];
        }
        return Math.max(dp[prices.length - 1][2], Math.max(dp[prices.length - 1][1],Math.max(dp[prices.length - 1][3],0)));
    }

买卖股票5

核心思路

  • 这一题主要是多了个手续费
  • 需要考虑手续费是买入的时候出, 还是卖出的时候出, 其实是一样的
  • 我选择买入的时候出手续费
java 复制代码
    public int maxProfit(int[] prices, int fee) {
        int[][] dp = new int[prices.length][2];
        dp[0][0] = -prices[0] - fee;
        dp[0][1] = 0;
        for (int i = 1; i < prices.length; i++) {
            dp[i][0] = Math.max(dp[i - 1][0], dp[i - 1][1] - fee - prices[i]);
            dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0] + prices[i]);
        }
        return dp[prices.length - 1][1];
    }
相关推荐
avocado_green1 分钟前
【LeetCode】90. 子集 II
算法·leetcode
tankeven6 分钟前
HJ178 【模板】双指针
c++·算法
君义_noip16 分钟前
信息学奥赛一本通 4131:【GESP2506六级】学习小组 | 洛谷 P13015 [GESP202506 六级] 学习小组
算法·动态规划·gesp·信息学奥赛
徒 花36 分钟前
HCIP学习19 BGP 跨自治系统互通综合实验
网络·学习·智能路由器·hcip·ensp
码喽7号37 分钟前
vue学习六:状态管理VueX
javascript·vue.js·学习
jiayong2337 分钟前
第 13 课:分页、页码状态和 URL 同步
开发语言·前端·javascript·vue.js·学习
6Hzlia44 分钟前
【Hot 100 刷题计划】 LeetCode 300. 最长递增子序列 | C++ 动态规划 & 贪心二分
c++·leetcode·动态规划
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 72. 编辑距离 | C++ 经典 DP 增删改状态转移
c++·算法·leetcode
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.16):距离最小相等元素查询
算法·leetcode·职场和发展
xuhaoyu_cpp_java1 小时前
MySql学习(四)
数据库·经验分享·笔记·sql·学习·mysql