【LeetCode】买卖股票的最佳时机最多两次购买机会

买卖股票的最佳时机

      • 题目描述
      • 算法分析
      • 程序代码

链接: 买卖股票的最佳时机

题目描述

【LeetCode】买卖股票的最佳时机最多两次购买机会_第1张图片

算法分析

【LeetCode】买卖股票的最佳时机最多两次购买机会_第2张图片

程序代码

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n = prices.size();
        vector<vector<int>> f(n,vector<int>(3,-0x3f3f3f));
        auto g = f;
        f[0][0] = -prices[0];
        g[0][0] = 0;
        for(int i = 1;i < n;++i)
        {
            for(int j = 0;j < 3;++j)
            {
                f[i][j] = max(f[i-1][j],g[i-1][j]-prices[i]);
                g[i][j] = g[i-1][j];
                if(j-1 >= 0)
                {
                    g[i][j] = max(g[i][j],f[i-1][j-1]+prices[i]);
                }
            }
        }

        return max(g[n-1][0],max(g[n-1][1],g[n-1][2]));
    }
};

【LeetCode】买卖股票的最佳时机最多两次购买机会_第3张图片

你可能感兴趣的:(leetcode,leetcode)