------------恢复内容开始------------
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
// 122. 买卖股票的最佳时机 II---199/200 个通过测试用例
// 可无数次交易
class Solution {
public:
int profit(vector<int>& prices, vector<int>& dp, int start)
{
int n=prices.size();
if(start>=n) return 0;
if(dp[start]) return dp[start];
int curMin = prices[start], res=0;
for(int i=start+1; i<n; ++i)
{
curMin = min(curMin, prices[i]);
res = max(res, prices[i]-curMin+profit(prices, dp, i+1));
}
dp[start]=res;
return res;
}
int maxProfit(vector<int>& prices) {
int n=prices.size();
vector<int> dp(n);
return profit(prices, dp, 0);
}
};
// 123. 买卖股票的最佳时机 III---202/214 个通过测试用例
// 可2次交易(代码同 188. 买卖股票的最佳时机 IV, 令k=2)
// 188. 买卖股票的最佳时机 IV---通过
// 执行用时:1280 ms, 在所有 C++ 提交中击败了5.50%的用户
// 内存消耗:11.6 MB, 在所有 C++ 提交中击败了47.99%的用户
// 可k次交易
class Solution {
public:
int profit(vector<int>& prices, vector<vector<int>>& dp, int start, int k)
{
int n=prices.size();
if(start>=n || k==0) return 0;
if(dp[start][k]) return dp[start][k];
int curMin = prices[start], res=0;
for(int i=start+1; i<n; ++i)
{
curMin = min(curMin, prices[i]);
res = max(res, prices[i]-curMin+profit(prices, dp, i+1, k-1));
}
dp[start][k]=res;
return res;
}
int maxProfit(int k, vector<int>& prices) {
int n=prices.size();
vector<vector<int>> dp(n, vector<int>(k+1));
return profit(prices, dp, 0, k);
}
};
// 309. 最佳买卖股票时机含冷冻期---通过
// 执行用时:152 ms, 在所有 C++ 提交中击败了12.22%的用户
// 内存消耗:11.1 MB, 在所有 C++ 提交中击败了54.00%的用户
// 可无数次交易 有一天冷冻期 (代码同122. 买卖股票的最佳时机 II i+1改成i+2隔天交易)
// 714. 买卖股票的最佳时机含手续费---34/44 个通过测试用例
// 可无数次交易(代码同122. 买卖股票的最佳时机,计算收益时减去手续费)
------------恢复内容结束------------