day35 动态规划 part08

股票类问题整体思考方向:
  • dpik0:第 ii 天,最多交易 kk 次,不持有股票 的最大收益
  • dpik1dpik1:第 ii 天,最多交易 kk 次,持有股票 的最大收益

若题目无交易次数限制或只记录"当前是否持有"两种状态:

  • dpi0dpi0:第 ii 天,不持有股票的最大收益
  • dpi1dpi1:第 ii 天,持有股票的最大收益
**问题1:**买卖股票的最佳时机I

题目:

https://leetcode.cn/problems/best-time-to-buy-and-sell-stock/description/

思路:

  • 像"选择一天买入,一天卖出",买入只能一次,卖出也只能一次,买入一定在卖出前。
  • 动态规划两个状态:
    • dpi0dpi0:第 ii 天持有股票,最大收益
    • dpi1dpi1:第 ii 天不持有股票,最大收益
  • 状态转移:
    • dpi0=max⁡(dpi−10,−pricesi)dpi0=max(dpi−10,−pricesi) # 要么不动,要么今天买入
    • dpi1=max⁡(dpi−11,dpi−10+pricesi)dpi1=max(dpi−11,dpi−10+pricesi) # 不动 or 今天卖了

代码:

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        /* 
            step1: dp[i][0] 持有股票的最大现金   dp[i][1] 不持有股票的最大现金
            step2: 
                   1. dp[i][0] = Math.max(dp[i-1],-prices[i]);
                   2. dp[i][1] = Math.max(dp[i-1][0],dp[i-1][0]+prices[i]);
            step3: dp[0][0] = -prices[0]; dp[0][1] = 0;
            step4: 正序遍历
            step5: 打印dp数组
         */
         int n = prices.length;
         int [][] dp = new int [n+1][2];
         dp[0][0] = -prices[0];
         dp[0][1] = 0;
         for(int i = 1; i < n; i++){
            dp[i][0] = Math.max(dp[i-1][0],-prices[i]);
            dp[i][1] = Math.max(dp[i-1][1],dp[i-1][0]+prices[i]);
         }
         return dp[n-1][1];
    }
}
**问题2:**买卖股票的最佳时机II

题目:

思路:

这里可以多次买卖,区别就是我的状态是变的 那么初始化就会影响

代码:

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        /* 
            step1: dp[i][0] 持有股票的最大现金   dp[i][1] 不持有股票的最大现金
            step2: 
                   1. dp[i][0] = Math.max(dp[i-1],-prices[i]);
                   2. dp[i][1] = Math.max(dp[i-1][0],dp[i-1][0]+prices[i]);
            step3: dp[0][0] = -prices[0]; dp[0][1] = 0;
            step4: 正序遍历
            step5: 打印dp数组
         */
         int n = prices.length;
         int [][] dp = new int [n+1][2];
         dp[0][0] = -prices[0];
         dp[0][1] = 0;
         for(int i = 1; i < n; i++){
            dp[i][0] = Math.max(dp[i-1][0],dp[i-1][1]-prices[i]);
            dp[i][1] = Math.max(dp[i-1][1],dp[i-1][0]+prices[i]);
         }
         return dp[n-1][1];
    }
}
**问题3:**买卖股票的最佳时机III

题目:

思路:

代码:

**问题4:**买卖股票的最佳时机IV

题目:

思路:

代码:

相关推荐
scx_link4 分钟前
线性回归的总结:
算法·机器学习·线性回归
郝亚军5 分钟前
IEEE 754 单精度浮点的SEM表示
开发语言·c++·算法
青山师9 分钟前
动态规划算法深度解析:从状态转移方程到工业级优化
数据结构·算法·面试·动态规划·代理模式·java面试
黎阳之光32 分钟前
数智透明·安全兜底|黎阳之光透明矿山,AI+数字孪生守护矿山生命线
人工智能·物联网·算法·安全·数字孪生
吴可可12341 分钟前
控制弦高精度的样条离散化方法
算法
wuweijianlove1 小时前
算法设计中的空间复用与数据对齐优化的技术5
算法
yuan199972 小时前
基于 MATLAB PSO 工具箱的函数寻优算法
开发语言·算法·matlab
YUANQIANG20242 小时前
博弈论中势函数与势博弈构造:为什么看似 “先射箭后画靶”
算法·信息与通信
WBluuue2 小时前
Codeforces 1096 Div3(ABCDEFGH)
c++·算法
wanzehongsheng2 小时前
基于天文算法的双轴太阳能追踪系统:从原理到工程实现
算法