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; } };