目录
121 买卖股票的最佳时机
class Solution {
public:
int maxProfit(vector<int>& prices) {
int len = prices.size();
//dp[i] 表示当前的最大利润
vector<vector<int>> dp(len, vector<int>(2, 0));
//初始化
//第二位是0代表持有股票,那就是买了
//第二位是1代表不持有股票,就是没买,那就是初始金额0
dp[0][0] = -prices[0];
dp[0][1] = 0;
for(int i = 1; i < len; i++){
dp[i][0] = max(dp[i-1][0], -prices[i]);
dp[i][1] = max(dp[i-1][1], dp[i-1][0] + prices[i]);
}
return dp[len - 1][1];
}
};
122 买卖股票的最佳时机II
class Solution {
public:
int maxProfit(vector<int>& prices) {
vector<vector<int>> dp(prices.size()+1, vector<int>(2,0));
dp[0][0] = -prices[0];
dp[0][1] = 0;
for(int i = 1; i < prices.size(); i++){
dp[i][0] = max(dp[i-1][0], dp[i-1][1] - prices[i]);
dp[i][1] = max(dp[i-1][1], dp[i-1][0] + prices[i]);
}
return dp[prices.size() - 1][1];
}
};