题目链接:122.买卖股票的最佳时机II
基于贪心的思路:
思路比较简单,主要学习如何用动态规划去做
class Solution {
public:
int maxProfit(vector<int>& prices) {
int cnt=0;
for(int i=0;i<prices.size()-1;i++)
{
cnt +=max(prices[i+1]-prices[i],0);
}
return cnt;
}
};
基于动态规划思路:
class Solution {
public:
int maxProfit(vector<int>& prices) {
int dp[30010][2];
memset(dp,0,sizeof dp);
/*
dp[i][1]表示第i天卖出股票后持有的最多现金
dp[i][0]表示第i天买入股票后持有的最多现金
*/
dp[0][0] -= prices[0];//第一天持有股票
int n = prices.size();
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 max(dp[n-1][0],dp[n-1][1]);
}
};