day113(3.15)——leetcode面试经典150

123. 买卖股票的最佳时机 III

123. 买卖股票的最佳时机 Ⅲ

题目:

题解:

java 复制代码
class Solution {
    // 可以买卖多次,但手里只能持有一股。
    // 最多可以完成 两笔 交易。
    // 因为可以多次买卖,所以"买入"的时候,可以用"上一次卖出赚的钱"来抵扣成本。
    public int maxProfit(int[] prices) {
        //如果当前股票的数量<2,直接就是不持有股票,利润为0
        if(prices==null||prices.length<2) {
            return 0;
        }
        int n = prices.length;
        int[][] dp = new int[n][4];
        //创建二维数组
        //int[i][0]: 第1次卖入后的最大收益
        //表示第i天没有股票,(可能之前有,但就在第i天卖掉了,也可能之前就没有,所以第i天也不买)
        dp[0][0]=0;
        //int[i][1]: 第1次买入后的最大收益
        //表示第i天有股票,(可能之前有,但第i天也不买,也可能之前就没有,所以第i天就买了)
        dp[0][1]=-prices[0];
        // dp[i][2]: 第2次卖入后的最大收益
        //表示第i天没有股票,买了->卖了->又买->卖了
        dp[0][2]=0;
        // dp[i][3]: 第2次买出后的最大收益
        //表示第i天有股票,买了->卖了->又买
        dp[0][3]=-prices[0];
        //遍历每一天的股票数
        for(int i=1;i<n;i++) {
            //dp[i][0]状态:要么之前卖的,要么今天卖(用第一次买入的状态 + 今天价格)
            dp[i][0] = Math.max(prices[i]+dp[i-1][1], dp[i-1][0]);
            //dp[i][1]状态:要么之前买的,要么今天刚买(初始资金0)
            dp[i][1] = Math.max(dp[i-1][1], -prices[i]);
            //dp[i][2]状态:要么之前卖的,要么今天卖(用第二次买入的状态 + 今天价格)
            dp[i][2] = Math.max(prices[i]+dp[i-1][3], dp[i-1][2]);
            //dp[i][3]状态:要么之前买的,要么今天刚买(用第一次卖出的利润 - 今天价格)
            dp[i][3] = Math.max(dp[i-1][0]-prices[i], dp[i-1][3]);
        }
        //一定是没有股票的时候能得到最大利润,如果当前有股票,那一定是亏钱的,且肯定是进行完了第二次交易后最大
        return dp[n-1][2];
    }
}
相关推荐
wearegogog123几秒前
动态时间规整(DTW):跨越时间维度的相似性度量
算法
ECT-OS-JiuHuaShan8 分钟前
渡劫代谢,好事多磨
数据库·人工智能·科技·学习·算法·生活
We་ct21 分钟前
LeetCode 64. 最小路径和:动态规划入门实战
开发语言·前端·算法·leetcode·typescript·动态规划
CoderCodingNo22 分钟前
【CSP】CSP-J 2019 江西真题 | 次大值 luogu-P5682 (适合GESP四、五级及以上考生练习)
开发语言·c++·算法
做cv的小昊30 分钟前
【TJU】应用统计学——第七周作业(4.2 多元线性回归分析、4.3 可化为线性回归的曲线回归、4.4 单因子方差分析)
线性代数·算法·数学建模·矩阵·回归·线性回归·概率论
被摘下的星星34 分钟前
子网de划分
网络·算法
Felven39 分钟前
A. Red Versus Blue
算法
꧁细听勿语情꧂1 小时前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
踩坑记录1 小时前
leetcode hot100 169. 多数元素 easy 技巧 摩尔投票
leetcode
水蓝烟雨1 小时前
3487. 删除后的最大子数组元素和
算法·leetcode·链表