题解 | #买卖股票的最好时机(四)#

买卖股票的最好时机(四)

https://www.nowcoder.com/practice/1c583d416d504b80821fbe4cc20404f3

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param prices int整型vector 
     * @param k int整型 
     * @return int整型
     */
    int maxProfit(vector<int>& prices, int k) {
        // write code here
        int n = prices.size();
        if (n == 0) return 0;

        // 如果交易次数大于天数的一半,相当于无限次交易
        if (k > n / 2) {
            int profit = 0;
            for (int i = 1; i < n; ++i) {
                if (prices[i] > prices[i - 1]) {
                    profit += prices[i] - prices[i - 1];
                }
            }
            return profit;
        }

        // dp[i][j][0] 表示第 i 天结束时,进行了 j 次交易,并且手中没有股票的最大利润
        // dp[i][j][1] 表示第 i 天结束时,进行了 j 次交易,并且手中持有一股股票的最大利润
        vector<vector<vector<int>>> dp(n, vector<vector<int>>(k + 1, vector<int>(2, 0)));
        for (int i = 0; i <= k; ++i) {
            dp[0][i][0] = 0;
            dp[0][i][1] = -prices[0];
        }

        for (int i = 1; i < n; ++i) {
            for (int j = 0; j <= k; ++j) {
                dp[i][j][0] = dp[i - 1][j][0];
                if (j > 0) {
                    dp[i][j][0] = max(dp[i][j][0], dp[i - 1][j][1] + prices[i]);
                }
                dp[i][j][1] = dp[i - 1][j][1];
                if (j > 0) {
                    dp[i][j][1] = max(dp[i][j][1], dp[i - 1][j - 1][0] - prices[i]);
                }
            }
        }

        int maxProfit = 0;
        for (int j = 0; j <= k; ++j) {
            maxProfit = max(maxProfit, dp[n - 1][j][0]);
        }

        return maxProfit;
    }
};

全部评论

相关推荐

04-03 11:37
武汉大学 Java
高斯林的信徒:武大简历挂?我勒个骚岗
点赞 评论 收藏
分享
03-10 20:35
已编辑
武汉大学 C++
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务